为什么选择SenecaJS ! 作者: 王十三 时间: 2018-10-22 分类: 默认分类 评论 可能是受到 docker 的影响吧, 本人不喜欢太复杂的东西,一直以来的理念就是一个工具就只是在做一件事情。 ** 简单 ** Seneca 是个很简单的框架。内部函数多数也就是使用两个函数 . 添加服务 seneca.add 执行服务 seneca.act 业务项目的时候,我们一般都只是有小数量的服务器,所以在应用上,我们可能不清楚那些服务会高负载,在使用Seneca之后,我们可以轻松吧切换多个服务窗口来支撑单独一条业务线。 ** 开发需要 ** 再接触微信 第三方平台开发的时候,发现对接的服务器需要使用一个对外可访问的地址(IP)。而我们平时并不能保证自己的工作环境有对外的地址。 这个时候,我们只需要保证接口在Seneca上正常运行。然后我们的开发在本地链接远程的微服务,即可。 ** 语法可爱 ** JSON 匹配语法 让我有种暖暖的感觉。
seneca 初识 作者: 王十三 时间: 2018-10-22 分类: NODE.JS 评论 **Seneca是Node.js微服务框架开发工具** 它的目的在于复制架构师和开发人员的服务想法,提供方法把代码融入到由模式所触发的逻辑行为中,这是根据用例所作用的模型。一旦被定义,模式就可以轻松转为API,使用用例和模式来定义消息内容。 **安装 ** npm install seneca --save -dev **入门代码** ```javascript /** * 参考 https://segmentfault.com/a/1190000011130919 **/ let seneca = require('seneca')(); //匹配参数 let pattern = { module: 'demo', action: 'greeting' }; //匹配方法 let action = function (msg, done) { done(null, { answer: 'hello, ' + msg.name }); } seneca.add(pattern, action); // 执行方法 var req = {module: 'demo', action: 'greeting', name:'Marlin'} seneca.act( req, function (error, result){ if ( error ) console.log(error); else console.log(result.answer); }) ``` **运行代码** ```shell hello, Marlin {"kind":"notice","notice":"hello seneca 0j97bzt5lj8q/1540217000612/9065/3.7.0/-","level":"info","seneca":"0j97bzt5lj8q/1540217000612/9065/3.7.0/-","when":1540217000750} ``` ** 结果分析 ** 执行方法中的JSON 对象 'module','action',两个属性与值 都与 匹配参数 中的相同,所以该对象就进入了匹配方法中。
MySQL 5.6 & 5.7最优配置文件模板 作者: 王十三 时间: 2018-01-03 分类: 服务器运维 评论 > http://www.innomysql.net/article/21730.html 整理了一份最新基于MySQL 5.6和5.7的配置文件模板, 基本上可以说覆盖90%的调优选项,用户只需根据自己的服务器配置稍作修改即可,如InnoDB缓冲池的大小、IO能力(innodb_buffer_pool_size,innodb_io_capacity)。特别注意,这份配置文件不用修改,可以直接运行在MySQL5.6和5.7的版本下, 这里使用了小小的技巧,具体可看配置文件。如果配置参数存在问题,也可以及时反馈,我们一起成长。 触发做这件事情的原因是大部分网络上的MySQL配置文件都非常非常古老,大多都是基于MySQL 5.1的版本,这导致了绝大部分MySQL并没有运行在最优的环境,从而导致一些错误的使用,亦或是灾难性事故的发生,比如数据丢失,主从数据不一致等。而这些问题早在5.6版本及以后的版本中得到了解决。 最后,抛弃你那所谓的、陈旧的、错误的MySQL配置文件,面向一个崭新的高性能、高可靠、高可扩展MySQL时代,你要做的就是下载这份配置文件并用于你的生产环境。配置如下: [client] user=davi password=88888888 [mysqld] ########basic settings######## server-id = 11 port = 3306 user = mysql bind_address = 10.166.224.32 autocommit = 0 character_set_server=utf8mb4 skip_name_resolve = 1 max_connections = 800 max_connect_errors = 1000 datadir = /data/mysql_data transaction_isolation = READ-COMMITTED explicit_defaults_for_timestamp = 1 join_buffer_size = 134217728 tmp_table_size = 67108864 tmpdir = /tmp max_allowed_packet = 16777216 sql_mode = "STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION,NO_ZERO_DATE,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER" interactive_timeout = 1800 wait_timeout = 1800 read_buffer_size = 16777216 read_rnd_buffer_size = 33554432 sort_buffer_size = 33554432 ########log settings######## log_error = error.log slow_query_log = 1 slow_query_log_file = slow.log log_queries_not_using_indexes = 1 log_slow_admin_statements = 1 log_slow_slave_statements = 1 log_throttle_queries_not_using_indexes = 10 expire_logs_days = 90 long_query_time = 2 min_examined_row_limit = 100 ########replication settings######## master_info_repository = TABLE relay_log_info_repository = TABLE log_bin = bin.log sync_binlog = 1 gtid_mode = on enforce_gtid_consistency = 1 log_slave_updates binlog_format = row relay_log = relay.log relay_log_recovery = 1 binlog_gtid_simple_recovery = 1 slave_skip_errors = ddl_exist_errors ########innodb settings######## innodb_page_size = 8192 innodb_buffer_pool_size = 6G innodb_buffer_pool_instances = 8 innodb_buffer_pool_load_at_startup = 1 innodb_buffer_pool_dump_at_shutdown = 1 innodb_lru_scan_depth = 2000 innodb_lock_wait_timeout = 5 innodb_io_capacity = 4000 innodb_io_capacity_max = 8000 innodb_flush_method = O_DIRECT innodb_file_format = Barracuda innodb_file_format_max = Barracuda innodb_log_group_home_dir = /redolog/ innodb_undo_directory = /undolog/ innodb_undo_logs = 128 innodb_undo_tablespaces = 3 innodb_flush_neighbors = 1 innodb_log_file_size = 4G innodb_log_buffer_size = 16777216 innodb_purge_threads = 4 innodb_large_prefix = 1 innodb_thread_concurrency = 64 innodb_print_all_deadlocks = 1 innodb_strict_mode = 1 innodb_sort_buffer_size = 67108864 ########semi sync replication settings######## plugin_dir=/usr/local/mysql/lib/plugin plugin_load = "rpl_semi_sync_master=semisync_master.so;rpl_semi_sync_slave=semisync_slave.so" loose_rpl_semi_sync_master_enabled = 1 loose_rpl_semi_sync_slave_enabled = 1 loose_rpl_semi_sync_master_timeout = 5000 [mysqld-5.7] innodb_buffer_pool_dump_pct = 40 innodb_page_cleaners = 4 innodb_undo_log_truncate = 1 innodb_max_undo_log_size = 2G innodb_purge_rseg_truncate_frequency = 128 binlog_gtid_simple_recovery=1 log_timestamps=system transaction_write_set_extraction=MURMUR32 show_compatibility_56=on
开始运行MYSQL 5.7 作者: 王十三 时间: 2018-01-03 分类: 服务器运维 评论 参考文档 > http://dev.mysql.com/doc/refman/5.7/en/json-search-functions.html 编辑my.cnf [mysqld] 下面增加 > sql_mode='ONLY_FULL_GROUP_BY,NO_AUTO_VALUE_ON_ZERO,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION,PIPES_AS_CONCAT,ANSI_QUOTES' 运行 MYSQL : > /etc/init.d/mysqld start > > mysql -uroot -p > JSON查询方法: > JSON_EXTRACT(json_doc, path[, path] ... 普通查询 mysql> SELECT JSON_EXTRACT('{"a":1,"b":0}','$.a') AS json ; +------+ | json | +------+ | 1 | +------+ 1 row in set (0.00 sec) 数组查询 mysql> SELECT JSON_EXTRACT('[10,20,30]','$[*]') AS json ; +--------------+ | json | +--------------+ | [10, 20, 30] | +--------------+ 1 row in set (0.00 sec) 查询数组 键值 内容 mysql> SELECT JSON_EXTRACT('{"a":1,"b":0,"c":[10,20,30]}','$.c[1]') AS json ; +------+ | json | +------+ | 20 | +------+ 1 row in set (0.00 sec) > JSON_SEARCH(json_doc, one_or_all, search_str[, escape_char[, path] ...]) > > one_or_all : one or all > > PS:适用于搜索数组 搜索数组 SELECT JSON_SEARCH('["1","0",["10","20","30"]]','one','1') AS json ; 结合JSON_EXTRACT SELECT JSON_SEARCH(JSON_EXTRACT('{"a":1,"b":0,"c":["10","20","30"]}','$.c'),'all','10') AS json ;
MYSQL 安装过程 作者: 王十三 时间: 2018-01-03 分类: 安装过程 评论 本次需要安装MYSQL 关系型数据库。 主要是要支持JSON的数据格式。 > 参考文档: http://dev.mysql.com/doc/refman/5.7/en/linux-installation-yum-repo.html > 安装环境: Vagrant Centos 6.7 下载MYSQL 配置 # wget http://dev.mysql.com/get/mysql57-community-release-el6-7.noarch.rpm # yum localinstall ./mysql57-community-release-el6-7.noarch.rpm # yum install mysql-community-server 修改ROOT密码 MYSQL 5.7 密码验证非常严格。 > /etc/my.cnf [mysqld] 下面增加 > skip-grant-tables > > update mysql.user set authentication_string=password('123qwe') where user='root' and Host = 'localhost'; //修改密码 > > update mysql.user set Host='%' where user='root' //不限制外部连接 > > flush privileges; 还原 my.cnf 文件 关闭防火墙 > /etc/selinux/config > > SELINUX=disabled > > setenforce 0 //临时生效 MYSQL Error : 2013 > SQL Error (2013): Lost connection to MySQL server at 'waiting for initial communication packet', system error: 0 vi /etc/sysconfig/iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT service iptables restart 个人配置 # Firewall configuration written by system-config-firewall # Manual customization of this file is not recommended. *filter :INPUT ACCEPT [0:0] :FORWARD ACCEPT [0:0] :OUTPUT ACCEPT [0:0] -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT -A INPUT -p icmp -j ACCEPT -A INPUT -i lo -j ACCEPT -A INPUT -i eth0 -j ACCEPT -A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT -A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT -A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT -A FORWARD -m state --state ESTABLISHED,RELATED -j ACCEPT -A FORWARD -p icmp -j ACCEPT -A FORWARD -i lo -j ACCEPT -A FORWARD -i eth0 -j ACCEPT -A INPUT -j REJECT --reject-with icmp-host-prohibited -A FORWARD -j REJECT --reject-with icmp-host-prohibited COMMIT