【轻知识】用cetus代理 mysql 用 etcd、confd 动态更换配置(未完待续)

实验机器:阿里云ECS 1核 2g centos 8

功能需求

cetus配置文件根据etcd配置代理mysql主从。

然后etcd put php新的配置

php配置文件 根据 新的配置进行更换。实现从直连到切入代理。

环境需要

openresty 、php 、confd 、etcd 、cetus 、mysql

mysql 别装5.8版本

装吧

openresty

centos http://openresty.org/cn/linux-packages.html

php

yum install php

confd

https://blog.csdn.net/bbwangj/article/details/82953786

模板语法 https://blog.csdn.net/ztsinghua/article/details/51643732?locationNum=3

mysql

版本的话选择5.7吧。5.8的话cetus编译不过去。我是centos8

https://blog.csdn.net/yanchao963852741/article/details/105297519/

etcd

https://github.com/etcd-io/etcd

cetus

https://github.com/cetus-tools/cetus

mkdir build/ && cd build/

装读写分离的版本吧

CFLAGS='-g -Wpointer-to-int-cast' cmake ../ -DCMAKE_BUILD_TYPE=Debug -DCMAKE_INSTALL_PREFIX=/home/user/cetus_install -DSIMPLE_PARSER=ON

把confd 跟etcd 运行起来

etcd

执行 etcd 执行下跑起来。你看端口哈。因为confd要指定node。

confd

confd 的配置目录(如果你自定义目录 可以用confd -confdir /data/confd)。

先把 testapp这个项目的配置都放好。testapp现在是手写的。实际上用后台添加,程序执行命令的方式用ssh 创建好对应的配置。这样比较更自动化。

另外,这个目录可根据自己项目灵活创建。

/etc/confd/
├── conf.d
│   └── testapp
│       └── config.toml
└── templates
    └── testapp
        └── config.tmpl

定时运行 confd -interval=60 -backend etcd -node http://127.0.0.1:2379 & (运行不知这一种模式,我上文的连接都有介绍)

confd 更换 php配置

nginx 配置

server {
    listen   80;
    server_name localhost;
    root    /www/testapp;
    access_log  /www/logs/nginx/testapp.access.log;
    error_log /www/logs/nginx/testapp.error.log;


    location / {
        index  index.php index.html index.htm;
           try_files $uri $uri/ /index.php?$query_string;
    }


    location ~ \.php$ {
        fastcgi_pass   unix:/run/php-fpm/www.sock;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
        include        fastcgi_params;
    }
}

代码demo目录

/www/testapp/
├── config.php # 放置配置
└── index.php # 打印打印东西,操作操作mysql

把配置 放到 confd目录下

testapp的config.toml

[root@i78igdnkcg5i9u5 testapp]# cat /etc/confd/conf.d/testapp/config.toml
[template]
prefix = 'testapp'
src = 'testapp/config.tmpl'
dest = '/www/testapp/config.php'
keys = [
"/dbconfig"
]

上面这个配置比较简单。如果你替换的是nginx 配置、twemproxy配置。需要用到两个选项

check_cmd = "/usr/local/openresty/nginx/sbin/nginx -t -c {{.src}}" #检查语法
reload_cmd = "/usr/local/openresty/nginx/sbin/nginx -s reload" #加载

配置模板

[root@iZ2ze78igdnkcg5i9u57cpZ testapp]# cat /etc/confd/templates/testapp/config.tmpl
<?php

return [
    "mysql"=>[
        {{ $dbconfig := json (getv "/dbconfig")}}
        'w'=>[
            {{range $dbconfig.Masters}}
            [
                "host"=> "{{.IP}}",
                "port"=> "{{.Port}}",
                "user"=> "{{.User}}",
                "pwd"=> "{{.Pwd}}"
            ],
            {{end}}
        ],
        'r'=> [
            {{range $dbconfig.Slaves}}
            [
                "host"=> "{{.IP}}",
                "port"=> "{{.Port}}",
                "user"=> "{{.User}}",
                "pwd"=> "{{.Pwd}}"
            ],
            {{end}}
        ]
    ]
];

实验替换

etcdctl put    /testapp/dbconfig '{"Masters":[{"IP":"127.0.0.1","User":"root","Pwd":"","Port":"3306"}],"Slaves":[{"IP":"127.0.0.1","User":"root","Pwd":"","Port":"3307"},{"IP":"127.0.0.1","User":"root","Pwd":"","Port":"3308"}]}'

为了方便观察 用 watch 命令 watch cat config.php

<?php

return [
    "mysql"=>[

    'w'=>[

                [
                    "host"=> "127.0.0.1",
                    "port"=> "3306",
                    "user"=> "root",
                    "pwd"=> ""
            ],

        ],
    'r'=> [

                [
                    "host"=> "127.0.0.1",
                    "port"=> "3307",
                    "user"=> "root",
                    "pwd"=> ""
            ],

                [
                    "host"=> "127.0.0.1",
                    "port"=> "3308",
                    "user"=> "root",
                    "pwd"=> ""
            ],

    ]
    ]
];

请求 http://39.107.233.96/ 内容变了

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容