设为首页 收藏本站
查看: 1001|回复: 0

[经验分享] OneProxy常用参数说明

[复制链接]

尚未签到

发表于 2017-7-9 10:10:15 | 显示全部楼层 |阅读模式
5.2、OneProxy常用参数说明
  OneProxy的所有可用参数可通过oneproxy --help-all查看。所有参数均可以写入文件中,由OneProxy启动时加载
5.2.1、基本参数
  --user=<user>
  以指定的用户运行oneproxy
  --pid-file=<file>
  指定oneproxy的进程pid文件路径
  --log-level=(error|warning|info|message|debug)
  指定oneproxy的日志输出级别
  --log-file=<file>
  指定日志文件的路径
  --keepalive
  开启进程守护,当oneproxy进程挂掉后重启oneproxy
  --max-open-files
  显示指定oneproxy的最大文件句柄数,默认Soft Limit为32768,Hard Limit为系统指定的大小
  --event-threads
  指定oneproxy的线程数,默认为8,建议为CPU的processor数量
  --max-idle-time
  在连接池中的连接最大空闲时间,指oneproxy与backends之间的连接,数据库中interactive_timeout的值要大于(max-idle-time+10),max-idle-time最大值为1800秒
  --proxy-address=<host:port>
  设定oneproxy提供服务的监听端口,在单机环境下,可指定监听IP及端口;在高可用环境下可忽略IP,例如--proxy-address=:3306
  --proxy-user-list=<user:passwd@dbname>
  设定在当前group中访问dbname的用户名和密码,其中密码是经过管理接口中passwd进行加密的字符串。建议在管理接口中使用passwd ‘password’;密码需用引号引起来,否则在使用特殊字符时密码会被截断
  --proxy-database=<dbname>
  设置通过oneproxy访问的默认数据库,默认为test库
  --mysql-version=<version>
  指定后端数据库的版本号,默认为5.5.18,此处主要是防止高版本的JDBC驱动连接oneproxy时,JAVA应用日志里出现“Caused by: java.sql.SQLException: Unknown system variable 'tx_read_only'”的错误导致应用无法启动。
  --proxy-connect-timeout=<number>
  设定oneproxy与后端建立连接的超时时间,默认为2秒
  --proxy-read-timeout=<number>
  设定oneproxy对后端进行读操作的超时时间,默认8小时
  --proxy-write-timeout=<number>
  设定oneproxy对后端进行写操作的超时时间,默认8小时
  --admin-address=<host:port>
  设定oneproxy管理接口的监听地址及端口
  --admin-username=<string>
  设定允许访问管理接口的用户名
  --admin-password=<string>
  设定允许访问管理接口的用户登陆密码
  --proxy-license=<license>
  针对企业版的注册码
  --proxy-charset=<charset>
  设定默认的字符集,默认为utf8_general_ci,可通过登陆管理接口并输入list charset查看oneproxy支持的所有字符集
5.2.2、读写分离
  --proxy-master-addresses=<host:port@servergroup>
  设定MySQL主服务器的地址、端口号及所属集群,例如
  --proxy-master-addresses=172.16.4.1:3306@cisco
  --proxy-slave-addresses=<host:port@servergroup>
  设定MySQL从服务器的地址、端口号及所属集群,例如
  --proxy-slave-addresses=172.16.4.2:3306@cisco
  --proxy-group-policy=<groupname:policy>
  设定在一个group中,数据库的读写分离策略,当前oneproxy支持12种读写分离策略
  支持一主多从场景的策略
  master_only:读写都在master
  read_failover:读写都在master,当master挂掉的时候读切到slaves
  read_slave:写在master,读在所有slaves
  read_balance:写在master,读从master以及slaves走
  big_slave:写以及简单查询走master,复杂查询走slaves
  big_balance:写及简单查询走master,复杂查询走master及slaves
  数据分片场景的策略
  write_shard:多组master的shard环境中,读写在任意master
  read_shard:一组多从的shard环境中,写在master,读走其他节点
  Percona XtraDB Cluster/MariaDB Galera Cluster环境
  write_balance
  write_other
  write_failover
  双主环境
  read_other
5.2.3、主从延迟检测
  --proxy-replication-check
  开启oneproxy的主从延迟精确检测功能,默认会在test库中创建一张表。原理类似pt-heartbeat
  --proxy-group-slavedelay=<servergroup:seconds>
  设定在一个group中的slave,在检测到复制延迟到达设置的值之后,自动剔除该节点,在延迟小于设定值时动态加入服务
  --repadmin-username=<string>
  设置用于主从检测的用户名
  --repadmin-password=<string>
  设置用于主从检测的用户名密码
5.2.4、高可用
  --vip-address=<ip/dev>
  在多节点HA环境下,设置提供服务的VIP地址以及VIP绑定的dev
  --remote-address=<host:port>
  设定在HA环境下,设置其他节点的管理接口IP和管理端口
  --proxy-server-id=<number>
  设置oneproxy的ID
5.2.5、性能抓取
  --proxy-trans-debug
  开启是否事务调试功能,帮助架构师、DBA分析在业务运行时的各个表之间所关联的query和trx的关系
  --proxy-log-sqlerror
  开启记录sql error
  --proxy-sql-debug
  开启sql debug功能
  
5.3、OneProxy实例管理

5.3.1、OneProxy单机多实例
  通过附录的脚本即可实现单机多个OneProxy实例

5.3.2、OneProxy管理接口
  OneProxy管理接口的连接
  mysql -uadminuser-padminpasswd -hOneProxyIP -POneProxyadminport
  其中
  adminuser:由参数admin-username指定,默认用户为admin
  adminpasswd:由参数admin-password指定,默认为OneProxy
  OneProxyIP:为OneProxy监听的服务器IP
  OneProxyadminport:为OneProxy监听的管理端口,默认为4041
  通过OneProxy的管理端口,通过动态调整运行参数(登陆后通过list命令可查看所有支持的指令),可满足如下需求:
  1、动态的调整Group中backend的最大最小连接池数量
  2、动态调整Group中读写分离策略
  3、动态调整Group中的安全策略

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-391886-1-1.html 上篇帖子: 用 bat 批处理 实现自动telnet 下篇帖子: 《最牛B的Linux Shell命令》笔记
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表