• 架构第二周作业


    第二周

    一、MyCAT中间件服务实现读写分离

    #三台服务器
    centos7  mycat-server  10.0.0.152  内存2G以上
    centos8  mysql-master  10.0.0.150  mariadb 10.3
    centos8  mysql-master  10.0.0.160  mariadb 10.3
    
    #1)创建数据库主从
    [root@centos8 ~]#yum install -y mariadb-server
    #master和slave修改配置文件
    #master:
    [root@centos8 ~]#vim /etc/my.cnf.d/mariadb-server.cnf
    [mysqld]#
    server-id=1
    log-bin
    
    #slave:
    [root@centos8 ~]#vim /etc/my.cnf.d/mariadb-server.cnf
    [mysqld]
    server-id=2
    
    #修改配置文件后重启服务使生效
    [root@centos8 ~]#systemctl start mariadb
    
    #master:创建复制账号
    [root@centos8 ~]#mysql
    Welcome to the MariaDB monitor.  Commands end with ; or \g.
    Your MariaDB connection id is 9
    Server version: 10.3.28-MariaDB-log MariaDB Server
    
    Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
    
    Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
    
    MariaDB [(none)]> grant replication slave on *.* to 'repluser'@'%' identified by 'replpass';
    Query OK, 0 rows affected (0.000 sec)
    
    MariaDB [(none)]> flush privileges;
    Query OK, 0 rows affected (0.000 sec)
    MariaDB [(none)]> show master logs;
    +--------------------+-----------+
    | Log_name           | File_size |
    +--------------------+-----------+
    | mariadb-bin.000001 |       645 |
    +--------------------+-----------+
    1 row in set (0.000 sec)
    
    
    #slave:连接主数据库
    MariaDB [(none)]> change master to master_host='10.0.0.150',master_user='repluser',master_password='replpass',master_log_file='mariadb-bin.000001',master_log_pos=645;
    Query OK, 0 rows affected (0.002 sec)
    MariaDB [(none)]> start slave;
    Query OK, 0 rows affected (0.001 sec)
    
    MariaDB [(none)]> show slave status \G;
    			......
                 Slave_IO_Running: Yes
                 Slave_SQL_Running: Yes
    			......省略
    			
    #2)在mysql代理服务器10.0.0.152上安装mycat并启动
    #安装jdk
    [root@localhost ~]# yum install -y java
    [root@localhost ~]# java -version
    openjdk version "1.8.0_312"
    OpenJDK Runtime Environment (build 1.8.0_312-b07)
    OpenJDK 64-Bit Server VM (build 25.312-b07, mixed mode)
    
    #下载并安装mycat
    [root@localhost ~]# wget http://dl.mycat.org.cn/1.6.7.6/20210303094759/Mycat-server-1.6.7.6-release-20210303094759-linux.tar.gz
    
    或者#wget http://dl.mycat.org.cn/1.6.7.4/Mycat-server-1.6.7.4-release/Mycat-server-1.6.7.4-release-20200105164103-linux.tar.gz
    
    [root@localhost ~]# mkdir /apps
    [root@localhost ~]# tar xvf Mycat-server-1.6.7.6-release-20210303094759-linux.tar.gz  -C /apps
    
    #配置环境变量
    [root@localhost ~]# echo 'PATH=$PATH:/apps/mycat/bin'>/etc/profile.d/mycat.sh
    [root@localhost ~]# source /etc/profile.d/mycat.sh
    
    #启动mycat
    [root@localhost ~]# ss -ntl
    State      Recv-Q Send-Q Local Address:Port               Peer Address:Port
    LISTEN     0      128               *:111                           *:*
    LISTEN     0      128               *:22                            *:*
    LISTEN     0      100       127.0.0.1:25                            *:*
    LISTEN     0      128            [::]:111                        [::]:*
    LISTEN     0      128            [::]:22                         [::]:*
    LISTEN     0      100           [::1]:25                         [::]:*
    [root@localhost ~]# mycat start
    Starting Mycat-server...
    [root@localhost ~]# ss -ntl
    State      Recv-Q Send-Q Local Address:Port               Peer Address:Port
    LISTEN     0      1         127.0.0.1:32000                         *:*
    LISTEN     0      128               *:111                           *:*
    LISTEN     0      128               *:22                            *:*
    LISTEN     0      100       127.0.0.1:25                            *:*
    LISTEN     0      50             [::]:1984                       [::]:*
    LISTEN     0      128            [::]:8066                       [::]:*
    LISTEN     0      50             [::]:43650                      [::]:*
    LISTEN     0      128            [::]:9066                       [::]:*
    LISTEN     0      128            [::]:111                        [::]:*
    LISTEN     0      128            [::]:22                         [::]:*
    LISTEN     0      100           [::1]:25                         [::]:*
    LISTEN     0      50             [::]:34334                      [::]:*
    
    #可以看到启动了多个端口,其中8066用于连接myscat
    [root@localhost ~]# tail /apps/mycat/logs/wrapper.log
    可以看到启动成功了
    
    #用默认密码123456来连接mycat
    [root@localhost ~]# mysql -uroot -p123456 -h10.0.0.152 -P8066
    Welcome to the MariaDB monitor.  Commands end with ; or \g.
    Your MySQL connection id is 1
    Server version: 5.6.29-mycat-1.6.7.6-release-20210303094759 MyCat Server (OpenCloudDB)
    
    Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
    
    Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
    
    MySQL [(none)]> show databases;
    +----------+
    | DATABASE |
    +----------+
    | TESTDB   |
    +----------+
    1 row in set (0.00 sec)
    
    #3)在mycat服务器上修改server.xml文件配置mycat的连接信息
    [root@localhost ~]# vim /apps/mycat/conf/server.xml
    #修改下面行的8066改为3306复制到到独立非注释行
    <property name="serverPort">3306</property>
    <property name="handlelDistributedTransactions">0</property> #将上面行放在此行前面
    或者删除注释,并修改下面的8066为3306
    <property name="serverPort">3306</property>
    <property name="managerPort">9066</property>
    <property name="idleTimeout">300000</property>
    <property name="authTimeout">15000</property>
    <property name="bindIp">0.0.0.0</property>
    <property name="dataNodeIdleCheckPeriod">300000</property> #5 * 60 * 1000L; //连
    接空闲检查 删除#后面此部分
    <property name="frontWriteQueueSize">4096</property> <property 
    name="processors">32</property> #--> 删除#后面此部分
     .....
    <user name="root">                                       #连接Mycat的用户名
       <property name="password">magedu</property>          #连接Mycat的密码
       <property name="schemas">TESTDB</property>           #数据库名要和schema.xml相
    对应
    
    
    #这里使用的是root,密码为magedu,逻辑数据库为TESTDB,这些信息都可以自己随意定义,读写权限都有,没有针对表做任何特殊的权限。重点关注上面这段配置,其他默认即可。
    
    #4)修改schema.xml实现读写分离策略
    [root@localhost ~]# vim /apps/mycat/conf/schema.xml
    #最终文件内容
    [root@mycat ~]#cat /apps/mycat/conf/schema.xml
    <?xml version="1.0"?>
    <!DOCTYPE mycat:schema SYSTEM "schema.dtd">
    <mycat:schema xmlns:mycat="http://io.mycat/">
     <schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100"
    dataNode="dn1">
     </schema>
     <dataNode name="dn1" dataHost="localhost1" database="hellodb" />
     <dataHost name="localhost1" maxCon="1000" minCon="10" balance="1"
      writeType="0" dbType="mysql" dbDriver="native" switchType="1"
    slaveThreshold="100">
     <heartbeat>select user()</heartbeat>
     <writeHost host="host1" url="10.0.0.18:3306" user="mycat"
       password="123456">
             <readHost host="host2" url="10.0.0.28:3306" user="mycat"
    password="123456" />
     </writeHost>
       </dataHost>
    </mycat:schema>
    
    #重新启动mycat
    root@localhost ~]# mycat restart
    Stopping Mycat-server...
    Mycat-server was not running.
    Starting Mycat-server...
    [root@localhost ~]# tail /apps/mycat/logs/wrapper.log
    INFO   | jvm 1    | 2021/11/09 22:49:04 |       at io.mycat.config.util.ConfigUtil.getDocument(ConfigUtil.java:115)
    INFO   | jvm 1    | 2021/11/09 22:49:04 |       at io.mycat.config.loader.xml.XMLSchemaLoader.load(XMLSchemaLoader.java:111)
    INFO   | jvm 1    | 2021/11/09 22:49:04 |       ... 13 more
    STATUS | wrapper  | 2021/11/09 22:49:06 | <-- Wrapper Stopped
    STATUS | wrapper  | 2021/11/09 22:53:37 | --> Wrapper Started as Daemon
    STATUS | wrapper  | 2021/11/09 22:53:38 | Launching a JVM...
    INFO   | jvm 1    | 2021/11/09 22:53:38 | Wrapper (Version 3.2.3) http://wrapper.tanukisoftware.org
    INFO   | jvm 1    | 2021/11/09 22:53:38 |   Copyright 1999-2006 Tanuki Software, Inc.  All Rights Reserved.
    INFO   | jvm 1    | 2021/11/09 22:53:38 |
    INFO   | jvm 1    | 2021/11/09 22:53:41 | MyCAT Server startup successfully. see logs in logs/mycat.log
    
    
    #5)在10.0.0.150的后端数据库创建用户并授权
    
    MariaDB [(none)]> grant all privileges on *.* to 'mycat'@'10.0.0.%' identified by '123456';
    Query OK, 0 rows affected (0.000 sec)
    
    MariaDB [(none)]> flush privileges;
    Query OK, 0 rows affected (0.000 sec)
    
    MariaDB [(none)]> exit
    Bye
    [root@centos8 ~]#mysql -h10.0.0.150 -umycat -p123456
    
    #6)连接并测试,可以看到进入逻辑数据库TESTDB,查到我后端hellodb数据库里面的内容,成功
    [root@localhost ~]# mysql -uroot -pmagedu -h10.0.0.152 TESTDB
    Reading table information for completion of table and column names
    You can turn off this feature to get a quicker startup with -A
    
    Welcome to the MariaDB monitor.  Commands end with ; or \g.
    Your MySQL connection id is 1
    Server version: 5.6.29-mycat-1.6.7.6-release-20210303094759 MyCat Server (OpenCloudDB)
    
    Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
    
    Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
    
    MySQL [TESTDB]> show databases;
    +----------+
    | DATABASE |
    +----------+
    | TESTDB   |
    +----------+
    1 row in set (0.00 sec)
    
    MySQL [TESTDB]> show tables;
    +-------------------+
    | Tables_in_hellodb |
    +-------------------+
    | tbl1              |
    +-------------------+
    1 row in set (0.00 sec)
    
    MySQL [TESTDB]> select * from tbl1;
    +------+----------+
    | id   | name     |
    +------+----------+
    |    1 | tanliang |
    +------+----------+
    1 row in set (0.00 sec)
    MySQL [TESTDB]> select @@hostname;
    +--------------------+
    | @@hostname         |
    +--------------------+
    | centos8.magedu.org |
    +--------------------+
    1 row in set (0.00 sec)
    
    MySQL [TESTDB]> select @@server_id;
    +-------------+
    | @@server_id |
    +-------------+
    |           2 |
    +-------------+
    1 row in set (0.00 sec)
    
    #7)通过日志确认实现读写分离
    show variables like 'general_log';  #查看日志是否开启
    set global general_log=on;    #开启日志功能
    show variables like 'general_log_file'; #查看日志文件保存位置
    set global general_log_file='tmp/general.log'; #设置日志文件保存位置
    
    #在主和从服务器分别开启通用日志,查看读写分离
    #操作:
    MySQL [TESTDB]> show tables;
    +-------------------+
    | Tables_in_hellodb |
    +-------------------+
    | tbl1              |
    +-------------------+
    1 row in set (0.00 sec)
    
    MySQL [TESTDB]> select * from tbl1;
    +------+----------+
    | id   | name     |
    +------+----------+
    |    1 | tanliang |
    +------+----------+
    1 row in set (0.01 sec)
    
    MySQL [TESTDB]> insert tbl1 value(2,'liang');
    Query OK, 1 row affected (0.01 sec)
    
    主:
    [root@master mysql]#tail -f centos8.log
    211109 23:03:41     20 Query    select user()
                        24 Connect  mycat@10.0.0.152 as anonymous on hellodb
    211109 23:03:51     17 Query    select user()
    211109 23:04:01     16 Query    SET names utf8;insert tbl1 value(2,'liang')
                        23 Query    select user()
    ^C
    从:
    211109 23:02:04     16 Query    SET names utf8;show tables
    211109 23:02:11     15 Query    select user()
    211109 23:02:21     13 Query    select user()
    211109 23:02:31     12 Query    select user()
    211109 23:02:41     14 Query    select user()
    211109 23:02:51     11 Query    select user()
    211109 23:03:01     16 Query    select user()
    211109 23:03:11     15 Query    select user()
    211109 23:03:12     13 Query    select * from tbl1
    211109 23:03:21     12 Query    select user()
    211109 23:03:31     14 Query    select user()
    211109 23:03:41     11 Query    select user()
                        18 Connect  mycat@10.0.0.152 as anonymous on hellodb
    211109 23:03:51     16 Query    select user()
    211109 23:04:01     10 Query    BEGIN
                        10 Query    insert tbl1 value(2,'liang')
                        10 Query    COMMIT /* implicit, from Xid_log_event */
                        15 Query    select user()
    #MyCAT对后端服务器的健康性检查方法select user()
    #停止从节点,MyCAT自动调度读请求至主节点,#停止主节点,MyCAT不会自动调度写请求至从节点
    slave上停止mariadb
    [root@slave1 mysql]#systemctl stop mariadb
    
    [root@localhost ~]# mysql -uroot -pmagedu -h10.0.0.152 TESTDB
    MySQL [TESTDB]> select @@server_id;
    +-------------+
    | @@server_id |
    +-------------+
    |           1 |
    +-------------+
    1 row in set (0.00 sec)
    

    二、ansible常用模块总结

    常用模块帮助文档参考:
    https://docs.ansible.com/ansible/2.9/modules/modules_by_category.html
    https://docs.ansible.com/ansible/2.9/modules/list_of_all_modules.html
    
    1)Command模块
    功能:在远程主机执行命令,此为默认模块,可忽略-m选项
    说明:此命令不支持 $VARNAME < > | ; & 等,可用shell模块实现。
    说明:此模块不具有幂等性(幂等性:多次执行不影响结果)
    #chdir切换工作目录
    [root@master tasks]#ansible webservers -m command -a "chdir=/etc cat centos-release"
    10.0.0.150 | CHANGED | rc=0 >>
    CentOS Linux release 8.3.2011
    10.0.0.160 | CHANGED | rc=0 >>
    CentOS Linux release 8.3.2011
    
    #不支持,所以输出了hello > /root/hello.log到屏幕,而没有把hello写入到文件中
    [root@master ~]#ansible webservers -m command  -a 'echo hello > /root/hello.log'
    10.0.0.150 | CHANGED | rc=0 >>
    hello > /root/hello.log
    10.0.0.160 | CHANGED | rc=0 >>
    hello > /root/hello.log
    
    #creates存在则不执行
    [root@master ~]#ansible webservers -m command  -a  'chdir=/etc creates=centos-release  cat centos-release'
    10.0.0.150 | SUCCESS | rc=0 >>
    skipped, since centos-release exists
    10.0.0.160 | SUCCESS | rc=0 >>
    skipped, since centos-release exists
    
    #creates不存在则执行
    [root@master ~]#ansible webservers -m command  -a  'chdir=/etc creates=f1.txt cat centos-release'
    10.0.0.150 | CHANGED | rc=0 >>
    CentOS Linux release 8.3.2011
    10.0.0.160 | CHANGED | rc=0 >>
    CentOS Linux release 8.3.2011
    
    
    #removes存在才执行
    [root@master ~]#ansible webservers -m command  -a  'chdir=/etc removes=centos-release  cat centos-release'
    10.0.0.150 | CHANGED | rc=0 >>
    CentOS Linux release 8.3.2011
    10.0.0.160 | CHANGED | rc=0 >>
    CentOS Linux release 8.3.2011
    
    #removes不存在不执行
    [root@master ~]#ansible webservers -m command  -a  'chdir=/etc removes=centos-rease  cat centos-release'
    10.0.0.150 | SUCCESS | rc=0 >>
    skipped, since centos-rease does not exist
    10.0.0.160 | SUCCESS | rc=0 >>
    skipped, since centos-rease does not exist
    
    [root@master ~]#ansible webservers -m command  -a  'service mariadb restart'
    [WARNING]: Consider using the service module rather than running 'service'.  If you
    need to use command because service is insufficient you can add 'warn: false' to this
    command task or set 'command_warnings=False' in ansible.cfg to get rid of this message.
    10.0.0.160 | CHANGED | rc=0 >>
    Redirecting to /bin/systemctl restart mariadb.service
    10.0.0.150 | CHANGED | rc=0 >>
    Redirecting to /bin/systemctl restart mariadb.service
    
    
    2)shell模块
    功能:和command相似,用shell执行命令,支持各种符号,比如:*,$, > 
    说明:此模块不具有幂等性
    说明:调用bash执行命令 类似 cat /tmp/test.md | awk -F'|' '{print $1,$2}' &> /tmp/example.txt 这些
    复杂命令,即使使用shell也可能会失败,解决办法:写到脚本时,copy到远程,执行,再把需要的结果
    拉回执行命令的机器
    
    [root@master ~]#ansible webservers -m shell -a 'echo $HOSTNAME'
    10.0.0.150 | CHANGED | rc=0 >>
    master
    10.0.0.160 | CHANGED | rc=0 >>
    slave1
    
    [root@master ~]#ansible webservers -m shell -a  'echo hello > /root/hello.log'
    10.0.0.150 | CHANGED | rc=0 >>
    
    10.0.0.160 | CHANGED | rc=0 >>
    
    [root@master ~]#ansible webservers -m shell -a  'cat /root/hello.log'
    10.0.0.150 | CHANGED | rc=0 >>
    hello
    10.0.0.160 | CHANGED | rc=0 >>
    hello
    
    可以把shell模块设置为默认模块
    [root@master ~]#vim ansible.cfg
    module_name = shell
    
    Ansible 的配置文件可以放在多个不同地方,优先级从高到低顺序如下
    ANSIBLE_CONFIG #环境变量,注意此项用 ansible --version 看不到,但可以生效
    ./ansible.cfg   #当前目录下的ansible.cfg
    ~/.ansible.cfg #当前用户家目录下的.ansible.cfg
    /etc/ansible/ansible.cfg  #系统默认配置文件
    
    3)script模块
    功能:在远程主机上运行ansible服务器上的脚本(无需执行权限)
    说明:此模块不具有幂等性
    脚本在当前机器上
    [root@master ~]#ansible webservers  -m script -a '/root/test.sh'
    
    
    4)copy模块
    功能:从主控端复制文件到远程主机
    说明: src=file 如果是没指明路径,则为当前目录或当前目录下的files目录下的file文件
    #如目标存在,默认覆盖,此处指定先备份
    [root@master ~]#ansible webservers -m copy -a "src=/root/test.sh dest=/tmp/test3.sh owner=mysql  mode=600 backup=yes"
    
    #指定内容,直接生成目标文件    
    [root@master ~]#ansible webservers -m copy -a "content='test line1\ntest line2\n' dest=/tmp/test.txt"
    [root@master ~]#cat /tmp/test.txt
    test line1
    test line2
    
    #复制/etc目录自身,注意/etc/后面没有/
    ansible webservers -m copy -a "src=/etc dest=/backup"
    
    #复制/etc/下的文件,不包括/etc/目录自身,注意/etc/后面有/
    ansible webservers -m copy -a "src=/etc/ dest=/backup"
    
    5)get_url模块
    功能: 用于将文件从http、https或ftp下载到被管理机节点上
    常用参数:
    url: 下载文件的URL,支持HTTP,HTTPS或FTP协议
    dest: 下载到目标路径(绝对路径),如果目标是一个目录,就用服务器上面文件的名称,如果目标设置了名称就用目标设置的名称
    owner:指定属主
    group:指定属组
    mode:指定权限
    force: 如果yes,dest不是目录,将每次下载文件,如果内容改变,替换文件。如果否,则只有在目标不存在时才会下载该文件
    checksum: 对目标文件在下载后计算摘要,以确保其完整性
               示例: checksum="sha256:D98291AC[...]B6DC7B97",
                   checksum="sha256:http://example.com/path/sha256sum.txt"
    url_username: 用于HTTP基本认证的用户名。 对于允许空密码的站点,此参数可以不使用`url_password'
    url_password: 用于HTTP基本认证的密码。 如果未指定`url_username'参数,则不会使用`url_password'参数validate_certs:如果“no”,SSL证书将不会被验证。 适用于自签名证书在私有网站上使用
    timeout: URL请求的超时时间,秒为单位
    
    [root@master ~]#ansible webservers -m get_url -a 'url=http://nginx.org/download/nginx-1.18.0.tar.gz dest=/usr/local/src/nginx.tar.gz checksum="md5:b2d33d24d89b8b1f87ff5d251aa27eb8"'
    [root@master ~]#ll /usr/local/src/nginx.tar.gz
    -rw-r--r-- 1 root root 1039530 Nov 11 17:57 /usr/local/src/nginx.tar.gz
    
    
    6)fethch模块
    功能:从远程主机提取文件至ansible的主控端,copy相反,目前不支持目录
    [root@master ~]#ansible webservers -m fetch -a 'src=/root/test.sh dest=.'
    
    [root@master ~]#tree
    .
    ├── 10.0.0.150
    │   └── root
    │       └── test.sh
    ├── 10.0.0.160
    │   └── root
    │       └── test.sh
    
    
    7)file模块
    功能:设置文件属性,创建软链接等
    #创建空文件
    [root@master ~]#ansible all -m file  -a 'path=/data/test.txt state=touch'
    #删除文件
    [root@master ~]#ansible all -m file  -a 'path=/data/test.txt state=absent'
    #设置文件权限
    [root@master ~]#ansible all -m file -a "path=/root/test.sh owner=wang mode=755"
    #创建目录
    [root@master ~]#ansible all -m file -a "path=/data/mysql state=directory owner=mysql group=mysql"
    #创建软链接,path|dest|name表示三个选一个都行
    [root@master ~]#ansible all -m file -a 'src=/data/testfile path|dest|name=/data/testfile-link state=link'
    #创建目录
    [root@master ~]#ansible all -m file  -a 'path=/data/testdir state=directory'
    #递归修改目录属性,但不递归至子目录
    [root@master ~]#ansible all -m file -a "path=/data/mysql state=directory owner=mysql group=mysql"
    #递归修改目录及子目录的属性
    [root@master ~]#ansible all -m file -a "path=/data/mysql state=directory owner=mysql group=mysql recurse=yes"
    
    8)stat模块
    功能:检查文件或文件系统的状态
    说明:对于Windows目标,请改用win_stat模块
    选项:path:文件/对象的完整路径(必须)
    常用的返回值判断:
    	exists: 判断是否存在
    	isuid: 调用用户的ID与所有者ID是否匹配
    [root@master data]#ansible 127.0.0.1 -m stat -a 'path=/etc/passwd'
    127.0.0.1 | SUCCESS => {
        "changed": false,
        "stat": {
            "atime": 1636603261.996736,
            "attr_flags": "",
            "attributes": [],
            "block_size": 4096,
            "blocks": 8,
            "charset": "us-ascii",
            "checksum": "358721bb9ccdb8b1eaf3a9b97e51d1eee306dd50",
            "ctime": 1636429959.9657238,
            "dev": 2053,
            "device_type": 0,
            "executable": false,
            "exists": true,
            "gid": 0,
            "gr_name": "root",
            "inode": 135872481,
            "isblk": false,
            "ischr": false,
            "isdir": false,
            "isfifo": false,
            "isgid": false,
            "islnk": false,
            "isreg": true,
            "issock": false,
            "isuid": false,
            "mimetype": "text/plain",
            "mode": "0644",
            "mtime": 1636429959.9647236,
            "nlink": 1,
            "path": "/etc/passwd",
            "pw_name": "root",
            "readable": true,
            "rgrp": true,
            "roth": true,
            "rusr": true,
            "size": 2814,
            "uid": 0,
            "version": "4213724205",
            "wgrp": false,
            "woth": false,
            "writeable": true,
            "wusr": true,
            "xgrp": false,
            "xoth": false,
            "xusr": false
        }
    }
    
    使用范例一:
    - name: install | Check if file is already configured.
     stat: path={{ nginx_file_path }}
     connection: local
     register: nginx_file_result
    - name: install | Download nginx file
     get_url: url={{ nginx_file_url }} dest={{ software_files_path }} validate_certs=no
     connection: local
     when:,not. nginx_file_result.stat.exists
    使用范例二:
    [root@ansible ansible]#cat stat.yml
    ---
    - hosts: websrvs
      
     tasks:
        - name: check file
         stat: path=/data/mysql 
         register: st
        - name: debug
         debug:
           msg: "/data/mysql is not exist"
         when: not st.stat.exists
         
         
    9)unarchive模块
    功能:解包解压缩
    实现有两种用法:
    1、将ansible主机上的压缩包传到远程主机后解压缩至特定目录,设置copy=yes,此为默认值,可省略
    2、将远程主机上的某个压缩包解压缩到指定路径下,设置copy=no 
    常见参数:
    copy:默认为yes,当copy=yes,拷贝的文件是从ansible主机复制到远程主机上,如果设置为copy=no,会在远程主机上寻找src源文件
    remote_src:和copy功能一样且互斥,yes表示在远程主机,不在ansible主机,no表示文件在ansible主机上
    src:源路径,可以是ansible主机上的路径,也可以是远程主机(被管理端或者第三方主机)上的路径,如果是远程主机上的路径,则需要设置copy=no
    dest:远程主机上的目标路径
    mode:设置解压缩后的文件权限
    
    [root@master ~]#ansible all -m unarchive -a 'src=/data/foo.tgz dest=/var/lib/foo owner=wang group=bin'
    [root@master ~]#ansible all -m unarchive -a 'src=/tmp/foo.zip dest=/data copy=no mode=0777'
    [root@master ~]#ansible all -m unarchive -a 'src=https://releases.ansible.com/ansible/ansible-2.1.6.0-0.1.rc1.tar.gz dest=/data copy=no'
    [root@master ~]#ansible all -m unarchive -a 'src=https://releases.ansible.com/ansible/ansible-2.1.6.0-0.1.rc1.tar.gz dest=/data/   owner=root remote_src=yes'
    [root@master ~]#ansible all -m unarchive -a 'src=http://nginx.org/download/nginx-1.18.0.tar.gz dest=/usr/local/src/ copy=no'
    
    
    10)archive模块
    功能:打包压缩保存在被管理节点
    
    [root@master ~]#ansible all -m archive -a 'path=/root/nginx-1.18.0  dest=/root/ngxin.tar.bz2 format=bz2  mode=0600'
    
    
    11)hostname模块
    功能:管理主机名
    [root@master ~]#ansible 10.0.0.150 -m hostname -a 'name=master111'
    
    
    12)cron模块
    功能:计划任务
    支持时间:minute,hour,day,month,weekday
    
    [root@master ~]#cat /root/mysql_backup.sh 
    #!/bin/bash
    mysqldump -A -F --single-transaction --master-data=2 -q -uroot |gzip > 
    /data/mysql_`date +%F_%T`.sql.gz
    #创建任务
    [root@master ~]#ansible 10.0.0.150 -m cron -a 'hour=2 minute=30 weekday=1-5 name="backup mysql" job=/root/mysql_backup.sh'
    [root@master ~]#ansible websrvs   -m cron -a "minute=*/5 job='/usr/sbin/ntpdate ntp.aliyun.com &>/dev/null' name=Synctime"
    #禁用计划任务
    [root@master ~]#ansible websrvs   -m cron -a "minute=*/5 job='/usr/sbin/ntpdate 172.20.0.1 &>/dev/null' name=Synctime disabled=yes"
    #启用计划任务
    [root@master ~]#ansible websrvs   -m cron -a "minute=*/5 job='/usr/sbin/ntpdate 172.20.0.1 &>/dev/null' name=Synctime disabled=no"
    #删除任务
    [root@master ~]#ansible websrvs -m cron -a "name='backup mysql' state=absent"
    [root@master ~]#ansible websrvs -m cron -a 'state=absent name=Synctime'
    
    13)yum和apt模块
    功能:
    yum 管理软件包,只支持RHEL,CentOS,fedora,不支持Ubuntu其它版本
    apt 模块管理 Debian 相关版本的软件包
    [root@master ~]#ansible websrvs -m yum -a 'name=httpd state=present'  #安装
    [root@master ~]#ansible websrvs -m yum -a 'name=nginx state=present enablerepo=epel'  #启用epel源进行安装
    [root@master ~]#ansible websrvs -m yum -a 'name=* state=lastest exclude=kernel*,foo*' #升级除kernel和foo开头以外的所有包
    [root@master ~]#ansible websrvs -m yum -a 'name=httpd state=absent'   #删除
    [root@master ~]#ansible websrvs -m yum -a 'name=sl,cowsay'
    [root@master ~]#ansible websrvs -m yum -a 
    "name=https://mirror.tuna.tsinghua.edu.cn/zabbix/zabbix/5.2/rhel/7/x86_64/zabbixagent-5.2.5-1.el7.x86_64.rpm"
    [root@centos8 ~]#ansible websrvs -m apt -a 'name=rsync,psmisc state=absent'
    [root@master ~]#ansible localhost -m yum -a "list=tree"
    
    14)yum_repository模块
    功能:配置yum仓库
    #创建yum仓库
    [root@master ~]#ansible localhost -m yum_repository  -a "name=test description='epel yum repo' file=external_repos baseurl=https://download.fedoraproject.org/pub/epel/$releasever/$basearch/ gpgcheck=no"
    localhost | CHANGED => {
        "changed": true,
        "repo": "test",
        "state": "present"
    }
    
    [root@master ~]#ls /etc/yum.repos.d/external_repos.repo
    /etc/yum.repos.d/external_repos.repo
    
    #删除仓库
    [root@master ~]#ansible localhost -m yum_repository  -a "name=test  file=external_repos state=absent"                                                                           localhost | CHANGED => {
        "changed": true,
        "repo": "test",
        "state": "absent"
    }
    [root@master ~]#ls /etc/yum.repos.d/external_repos.repo                                 ls: cannot access '/etc/yum.repos.d/external_repos.repo': No such file or directory
    
    15)service模块
    功能:管理服务
    [root@master ~]#ansible all -m service -a 'name=httpd state=started enabled=yes'
    [root@master ~]#ansible all -m service -a 'name=httpd state=stopped'
    [root@master ~]#ansible all -m service -a 'name=httpd state=reloaded'
    [root@master ~]#ansible all -m shell -a "sed -i 's/^Listen 80/Listen 8080/' 
    /etc/httpd/conf/httpd.conf"
    [root@master ~]#ansible all -m service -a 'name=httpd state=restarted'
    
    
    16)user模块
    功能:管理用户
    #创建用户
    [root@master ~]#ansible all -m user -a 'name=nginx comment=nginx uid=88  groups="root,daemon" shell=/sbin/nologin system=yes create_home=no home=/data/nginx non_unique=yes'
    
    #remove=yes表示删除用户及家目录等数据,默认remove=no
    [root@master ~]#ansible all -m user -a 'name=nginx state=absent remove=yes'
    
    #生成123456加密的密码
    [root@master ~]#ansible localhost -m debug -a "msg={{ '123456'| 
    password_hash('sha512','salt')}}"
    localhost | SUCCESS => {
        "msg": "$6$salt$MktMKPZJ6t59GfxcJU20DwcwQzfMvOlHFVZiOVD71w."
    }
    #用上面创建的密码创建用户
    [root@master ~]#ansible websrvs -m user -a 'name=test password="$6$salt$MktMKPZJ6t59GfxcJU20DwcwQzfMvOlHFVZiOVD71w."'
    
    #创建用户test,并生成4096bit的私钥
    [root@master ~]#ansible websrvs -m user -a 'name=test generate_ssh_key=yes ssh_key_bits=4096 ssh_key_file=.ssh/id_rsa'
    
    17)group模块
    功能:管理组
    #创建组
    [root@master ~]#ansible websrvs -m group  -a 'name=nginx gid=88 system=yes'
    #删除组
    [root@master ~]#ansible websrvs -m group  -a 'name=nginx state=absent'
    
    
    18)lineinfile模块
    ansible在使用sed进行替换时,经常会遇到需要转义的问题,而且ansible在遇到特殊符号进行替换时,存在问题,无法正常进行替换 。其实在ansible自身提供了两个模块:lineinfile模块和replace模块,可以方便的进行替换
    
    一般在ansible当中去修改某个文件的单行进行替换的时候需要使用lineinfile模块
    
    regexp参数 :使用正则表达式匹配对应的行,当替换文本时,如果有多行文本都能被匹配,则只有最后面被匹配到的那行文本才会被替换,当删除文本时,如果有多行文本都能被匹配,这么这些行都会被删除。
    
    如果想进行多行匹配进行替换需要使用replace模块
    
    功能:相当于sed,可以修改文件内容
    
    [root@master ~]#ansible websrvs -m lineinfile -a "path=/etc/httpd/conf/httpd.conf regexp='^Listen' line='Listen 80'"
    [root@master ~]#ansible all -m   lineinfile -a "path=/etc/selinux/config regexp='^SELINUX=' line='SELINUX=disabled'"
    [root@master ~]#ansible all -m lineinfile  -a 'dest=/etc/fstab state=absent regexp="^#"'
    
    19)replace模块
    该模块有点类似于sed命令,主要也是基于正则进行匹配和替换,建议使用
    [root@master ~]#ansible all -m replace -a "path=/etc/fstab regexp='^(UUID.*)' replace='#\1'"  
    [root@master ~]#ansible all -m replace -a "path=/etc/fstab regexp='^#(UUID.*)' replace='\1'"
    
    
    20)SELinux 模块
    该模块管理 SELInux 策略
    [root@master ~]#ansible all -m selinux -a 'state=disabled'
    
    
    21)reboot模块
    功能:重启服务器
    [root@master ~]#ansible websrvs -m reboot
    
    
    22)mount 挂载和卸载
    功能: 挂载和卸载文件系统
    #临时挂载
    [root@master ~]#mount 10.0.0.150 -m mount -a 'src="UUID=b3e48f45-f933-4c8e-a700-22a159ec9077" path=/home fstype=xfs opts=noatime state=present'
    #临时取消挂载
    [root@master ~]#mount all -m mount -a 'path=/home fstype=xfs opts=noatime state=unmounted'
    #永久挂载
    [root@master ~]#ansible all -m mount -a 'src=10.0.0.150:/data/wordpress path=/var/www/html/wp-content/uploads opts="_netdev" state=mounted'
    #永久卸载
    [root@master ~]#ansible all -m mount -a 'src=10.0.0.150:/data/wordpress path=/var/www/html/wp-content/uploads state=absent'
    
    23)Setup 模块
    功能: setup 模块来收集主机的系统信息,这些 facts 信息可以直接以变量的形式使用,但是如果主机较多,会影响执行速度
    可以使用 gather_facts: no 来禁止 Ansible 收集 facts 信息
    
    [root@master ~]#ansible all -m setup
    [root@master ~]#ansible all -m setup -a "filter=ansible_nodename"
    [root@master ~]#ansible all -m setup -a "filter=ansible_hostname"
    [root@master ~]#ansible all -m setup -a "filter=ansible_domain"
    [root@master ~]#ansible all -m setup -a "filter=ansible_memtotal_mb"
    [root@master ~]#ansible all -m setup -a "filter=ansible_memory_mb"
    [root@master ~]#ansible all -m setup -a "filter=ansible_memfree_mb"
    [root@master ~]#ansible all -m setup -a "filter=ansible_os_family"
    [root@master ~]#ansible all -m setup -a "filter=ansible_distribution_major_version"
    [root@master ~]#ansible all -m setup -a "filter=ansible_distribution_version"
    [root@master ~]#ansible all -m setup -a "filter=ansible_processor_vcpus"
    [root@master ~]#ansible all -m setup -a "filter=ansible_all_ipv4_addresses"
    [root@master ~]#ansible all -m setup -a "filter=ansible_architecture"
    [root@master ~]#ansible all -m setup -a "filter=ansible_uptime_seconds"
    [root@master ~]#ansible all -m setup -a "filter=ansible_processor*"
    [root@master ~]#ansible all -m setup -a 'filter=ansible_env'
    [root@master ~]#ansible all -m setup -a 'filter=ansible_all_ipv4_addresses'
    [root@master ~]#ansible all -m setup -a 'filter=ansible_python_version'
    [root@master ~]#ansible all -m setup -a 'filter="ansible_default_ipv4"'
    
    24)debug 模块
    此模块可以用于输出信息,并且通过 msg 定制输出的信息内容
    注意: msg后面的变量有时需要加 " " 引起来
    
    debug 模块默认输出Hello world
    [root@master ~]#ansible all -m debug
    10.0.0.150 | SUCCESS => {
        "msg": "Hello world!"
    }
    
    [root@master ~]#ansible all -m debug -a 'msg="HOSTNAME"'
    10.0.0.150 | SUCCESS => {
        "msg": "HOSTNAME"
    }
    
    #利用debug模块输出变量
    [root@master ~]#cat debug.yaml 
    ---
    - hosts: websrvs
      
     tasks: 
        - name: output variables
         debug:
           msg: Host "{{ ansible_nodename }}" Ip  "{{ ansible_default_ipv4.address }}"
    
    #显示特定字符
    # cat debug.yml
    - hosts: all
     gather_facts: no
     vars:
       a: "12345"
     tasks:
      - debug:
         msg: "{{a[2]}}"
    #定义了一个字符串变量a,如果想要获取a字符串的第3个字符,则可以使用”a[2]”获取,索引从0开始,执行上例playbook,debug的输出信息如下:
    
    [root@master tasks]#ansible-playbook /root/debug.yml
    
    PLAY [all] *****************************************************************************
    
    TASK [debug] ***************************************************************************
    ok: [10.0.0.150] => {
        "msg": "3"
    }
    ok: [10.0.0.160] => {
        "msg": "3"
    }
    

    三、ansible-playbook批量安装httpd,按主机名提供不同的index.html(如node1的index.html欢迎页面为welcome node1)

    [root@ansible ~]# vim /etc/ansible/hosts
    [webservers]
    10.0.0.150 ansible_connection=local
    10.0.0.160 
    
    #创建角色相关目录
    [root@ansible html]# mkdir -pv /data/ansible/roles/httpd/{tasks,handlers,files}
    mkdir: created directory '/data/ansible'
    mkdir: created directory '/data/ansible/roles'
    mkdir: created directory '/data/ansible/roles/httpd'
    mkdir: created directory '/data/ansible/roles/httpd/tasks'
    mkdir: created directory '/data/ansible/roles/httpd/handlers'
    mkdir: created directory '/data/ansible/roles/httpd/files'
    
    #创建角色相关文件
    [root@ansible html]# cd /data/ansible/roles/httpd/
    
    #main.yml是task的入口文件
    [root@ansible httpd]# vim tasks/main.yml
    - include: group.yml
    - include: user.yml
    - include: install.yml
    - include: config.yml
    - include: index.yml
    - include: service.yml
    
    [root@ansible httpd]# vim tasks/group.yml
    - name: create apache group
      group: name=apache system=yes gid=80
    
    [root@ansible httpd]# vim tasks/user.yml
    - name: create apache user
      user: name=apache system=yes shell=/sbin/nologin home=/var/www/ uid=80 group=apache
    
    [root@ansible httpd]# vim tasks/install.yml
    - name: install httpd package
      yum: name=httpd
    
    [root@ansible httpd]# vim tasks/config.yml
    - name: config file
      copy: src=httpd.conf  dest=/etc/httpd/conf/ backup=yes
      notify: restart
    
    [root@ansible httpd]# vim tasks/index.yml
     - name: index.html
      copy: content='{{ ansible_hostname }}\n'  dest=/var/www/html/index.html
    
    [root@ansible httpd]# vim tasks/service.yml
    - name: start httpd service
      service: name=httpd state=started enabled=yes
    
    [root@ansible httpd]# vim handlers/main.yml
    - name: restart
      service: name=httpd state=restarted
    
    #file目录下准备httpd.conf配置文件
    [root@ansible httpd]# ls files/httpd.conf
    files/httpd.conf
    
    [root@ansible httpd]# tree /data/ansible/roles/httpd/
    /data/ansible/roles/httpd/
    ├── files
    │   └── httpd.conf
    ├── handlers
    │   └── main.yml
    └── tasks
        ├── config.yml
        ├── group.yml
        ├── index.yml
        ├── install.yml
        ├── main.yml
        ├── service.yml
        └── user.yml
    3 directories, 9 files
    
    #在playbook中调用角色
    [root@ansible ~]# vim /data/ansible/role_httpd.yml
    - hosts: webservers
      remote_user: root
    
      roles:
        - httpd
    
    #运行playbook
    [root@ansible ~]# ansible-playbook  /data/ansible/role_httpd.yml
    
    #验证:
    [root@ansible ~]# curl 10.0.0.150
    ansible
    [root@ansible ~]# curl 10.0.0.160
    node1
    

    四、编译安装redis

    #安装依赖包
    [root@centos7 ~]#yum -y install gcc jemalloc-devel
    
    #下载源码
    [root@centos7 ~]#wget http://download.redis.io/releases/redis-5.0.7.tar.gz
    [root@centos7 ~]#tar xvf redis-5.0.7.tar.gz
    
    #编译安装
    [root@centos7 ~]#cd redis-5.0.7/
    [root@centos7 redis-5.0.7]#make PREFIX=/apps/redis install #指定redis安装目录
    
    #配置变量
    [root@centos7 ~]#echo 'PATH=/apps/redis/bin:$PATH' > /etc/profile.d/redis.sh
    [root@centos7 ~]#. /etc/profile.d/redis.sh
    
    #目录结构
    [root@centos7 ~]#tree /apps/redis/
    /apps/redis/
    └── bin
       ├── redis-benchmark
       ├── redis-check-aof
       ├── redis-check-rdb
       ├── redis-cli
       ├── redis-sentinel -> redis-server
       └── redis-server
    1 directory, 6 files
    
    #准备相关目录和配置文件
    [root@centos7 ~]#mkdir /apps/redis/{etc,log,data,run} #创建配置文件、日志、数据等目录
    [root@centos7 redis-5.0.7]#cp redis.conf /apps/redis/etc/
    
    #启动redis服务
    [root@centos7 ~]#redis-server /apps/redis/etc/redis.conf 
    27569:C 16 Feb 2020 21:18:20.412 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
    27569:C 16 Feb 2020 21:18:20.412 # Redis version=5.0.7, bits=64, 
    commit=00000000, modified=0, pid=27569, just started
    27569:C 16 Feb 2020 21:18:20.412 # Configuration loaded
    27569:M 16 Feb 2020 21:18:20.413 * Increased maximum number of open files to 
    10032 (it was originally set to 1024).
    
    #创建 redis 用户和数据目录
    [root@centos7 ~]#useradd -r -s /sbin/nologin redis
    #设置目录权限
    [root@centos7 ~]#chown -R redis.redis /apps/redis/  
    
    #编辑 redis 服务启动文件
    #复制CentOS8安装生成的redis.service文件,进行修改
    [root@centos7 ~]#scp 10.0.0.8:/lib/systemd/system/redis.service 
    /lib/systemd/system/
    [root@centos7 ~]#vim /usr/lib/systemd/system/redis.service
    [root@centos7 ~]#cat /usr/lib/systemd/system/redis.service
    [Unit]
    Description=Redis persistent key-value database
    After=network.target
    [Service]
    ExecStart=/apps/redis/bin/redis-server /apps/redis/etc/redis.conf --supervised
    systemd
    ExecStop=/bin/kill -s QUIT $MAINPID
    Type=notify
    User=redis
    Group=redis
    RuntimeDirectory=redis
    RuntimeDirectoryMode=0755
    [Install]
    WantedBy=multi-user.target
    
    #验证 redis 启动
    [root@centos7 ~]#systemctl daemon-reload 
    [root@centos7 ~]#systemctl start redis
    [root@centos7 ~]#systemctl status redis
    ● redis.service - Redis persistent key-value database
       Loaded: loaded (/usr/lib/systemd/system/redis.service; enabled; vendor 
    preset: disabled)
       Active: active (running) since Sun 2020-02-16 23:08:08 CST; 2s ago
     Process: 1667 ExecStop=/bin/kill -s QUIT $MAINPID (code=exited, 
    status=0/SUCCESS)
     Main PID: 1669 (redis-server)
       CGroup: /system.slice/redis.service
               └─1669 /apps/redis/bin/redis-server 127.0.0.1:6379
    [root@centos7 ~]#ss -ntl
    State     Recv-Q Send-Q     Local Address:Port               Peer Address:Port 
            
    LISTEN     0      100             127.0.0.1:25                           *:*   
              
    LISTEN     0      511             127.0.0.1:6379                         *:*   
              
    LISTEN     0      128                     *:22                           *:*   
              
    LISTEN     0      100                 [::1]:25                         [::]:*   
              
    LISTEN     0      128                 [::]:22                         [::]:*
    
    #使用客户端连接 redis
    [root@centos7 ~]#redis-cli 
    127.0.0.1:6379> ping
    PONG
    127.0.0.1:6379> info
    # Server
    redis_version:5.0.7
    redis_git_sha1:00000000
    redis_git_dirty:0
    redis_build_id:673d8c0ee1a8872
    redis_mode:standalone
    os:Linux 3.10.0-1062.el7.x86_64 x86_64
    arch_bits:64
    multiplexing_api:epoll
    atomicvar_api:atomic-builtin
    gcc_version:4.8.5
    process_id:1669
    run_id:5e0420e92e35ad1d740e9431bc655bfd0044a5d1
    tcp_port:6379
    uptime_in_seconds:140
    uptime_in_days:0
    hz:10
    configured_hz:10
    lru_clock:4807524
    executable:/apps/redis/bin/redis-server
    config_file:/apps/redis/etc/redis.conf
    # Clients
    connected_clients:1
    client_recent_max_input_buffer:2
    client_recent_max_output_buffer:0
    blocked_clients:0
    # Memory
    used_memory:575792
    used_memory_human:562.30K
    used_memory_rss:3506176
    used_memory_rss_human:3.34M
    used_memory_peak:575792
    used_memory_peak_human:562.30K
    used_memory_peak_perc:100.18%
    used_memory_overhead:562590
    used_memory_startup:512896
    used_memory_dataset:13202
    used_memory_dataset_perc:20.99%
    allocator_allocated:1201392
    allocator_active:1531904
    allocator_resident:8310784
    total_system_memory:1019645952
    total_system_memory_human:972.41M
    used_memory_lua:37888
    used_memory_lua_human:37.00K
    used_memory_scripts:0
    used_memory_scripts_human:0B
    number_of_cached_scripts:0
    maxmemory:0
    maxmemory_human:0B
    maxmemory_policy:noeviction
    allocator_frag_ratio:1.28
    allocator_frag_bytes:330512
    allocator_rss_ratio:5.43
    allocator_rss_bytes:6778880
    rss_overhead_ratio:0.42
    rss_overhead_bytes:-4804608
    mem_fragmentation_ratio:6.57
    mem_fragmentation_bytes:2972384
    mem_not_counted_for_evict:0
    mem_replication_backlog:0
    mem_clients_slaves:0
    mem_clients_normal:49694
    mem_aof_buffer:0
    mem_allocator:jemalloc-5.1.0
    active_defrag_running:0
    lazyfree_pending_objects:0
    # Persistence
    loading:0
    rdb_changes_since_last_save:0
    rdb_bgsave_in_progress:0
    rdb_last_save_time:1581865688
    rdb_last_bgsave_status:ok
    rdb_last_bgsave_time_sec:-1
    rdb_current_bgsave_time_sec:-1
    rdb_last_cow_size:0
    aof_enabled:0
    aof_rewrite_in_progress:0
    aof_rewrite_scheduled:0
    aof_last_rewrite_time_sec:-1
    aof_current_rewrite_time_sec:-1
    aof_last_bgrewrite_status:ok
    aof_last_write_status:ok
    aof_last_cow_size:0
    # Stats
    total_connections_received:1
    total_commands_processed:2
    instantaneous_ops_per_sec:0
    total_net_input_bytes:45
    total_net_output_bytes:11475
    instantaneous_input_kbps:0.00
    instantaneous_output_kbps:0.00
    rejected_connections:0
    sync_full:0
    sync_partial_ok:0
    sync_partial_err:0
    expired_keys:0
    expired_stale_perc:0.00
    expired_time_cap_reached_count:0
    evicted_keys:0
    keyspace_hits:0
    keyspace_misses:0
    pubsub_channels:0
    pubsub_patterns:0
    latest_fork_usec:0
    migrate_cached_sockets:0
    slave_expires_tracked_keys:0
    active_defrag_hits:0
    active_defrag_misses:0
    active_defrag_key_hits:0
    active_defrag_key_misses:0
    # Replication
    role:master
    connected_slaves:0
    master_replid:f7228f0b6203183004fae8db00568f9f73422dc4
    master_replid2:0000000000000000000000000000000000000000
    master_repl_offset:0
    second_repl_offset:-1
    repl_backlog_active:0
    repl_backlog_size:1048576
    repl_backlog_first_byte_offset:0
    repl_backlog_histlen:0
    # CPU
    used_cpu_sys:0.132821
    used_cpu_user:0.124317
    used_cpu_sys_children:0.000000
    used_cpu_user_children:0.000000
    # Cluster
    cluster_enabled:0
    # Keyspace
    127.0.0.1:6379> exit
    [root@centos7 ~]#
  • 相关阅读:
    Jenkins历史构建作业jobs的删除与管理
    Redis消息队列与主流的消息队列中间件对比
    GDAL数据模型
    Android的语言切换
    GDAL驱动实现向导
    Win7 安装IIS
    局域网中其他机器不能访问本机IIS网站
    DXF库(dxflib)使用指南
    GDAL中文学习资料
    QT的中文站址
  • 原文地址:https://www.cnblogs.com/tanll/p/16057302.html
Copyright © 2020-2023  润新知