DAY46 一键部署LNMP架构

将安装包传到/opt/目录下

nignx安装包:nginx-1.12.2.tar.gz

mysql安装包:mysql-boost-5.7.20.tar.gz

php安装包:php-7.1.10.tar.bz2

Discuz论坛安装包:Discuz_X3.4_SC_UTF8.zip

 #======编译安装nginx服务======
 ​
 #安装所需开发包和编译环境、编译器
 rm -f /var/run/yum.pid 
 yum -y install pcre-devel zlib-devel openssl-devel gcc gcc-c++ make
 ​
 #如果yum安装失败,则退出脚本
 [ $? != 0 ] && exit
 ​
 #创建程序用户,便于准确控制访问
 useradd -M -s /sbin/nologin nginx
 ​
 #解压安装包
 cd /opt
 tar zxvf nginx-1.12.2.tar.gz -C /opt
 ​
 #指定安装路径、指定用户名、组名、启用模块以支持统计状态
 cd nginx-1.12.2/
 ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module --with-file-aio --with-http_gzip_static_module --with-http_flv_module --with-http_ssl_module
 ​
 ​
 #编译及安装,开2核编译,注意虚拟机的处理器数量要设置为2
 make -j 2 && make install
 ​
 #软链接便于系统识别nginx操作命令
 ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
 ​
 #添加nginx系统服务
 echo '[Unit]
 Description=nginx
 After=network.target
 [Service]
 Type=forking
 PIDFile=/usr/local/nginx/logs/nginx.pid
 ExecStart=/usr/local/nginx/sbin/nginx
 ExecrReload=/bin/kill -s HUP $MAINPID
 ExecrStop=/bin/kill -s QUIT $MAINPID
 PrivateTmp=true
 [Install]
 WantedBy=multi-user.target' > /lib/systemd/system/nginx.service
 ​
 #赋权及开启服务、开启开机自启
 chmod 754 /lib/systemd/system/nginx.service
 systemctl start nginx.service
 systemctl enable nginx.service

编译安装mysql服务

写一个一键安装mysql服务的脚本

 #=======编译安装mysql服务=======
 ​
 #安装Mysql环境依赖包
 rm -f /var/run/yum.pid 
 yum -y install \
 expect \                   #安装expect免交互工具
 gcc \
 gcc-c++ \
 ncurses \
 ncurses-devel \
 bison \
 cmake
 ​
 #如果yum安装失败,则退出脚本
 [ $? != 0 ] && exit
 ​
 #创建程序用户,便于准确控制访问用户
 useradd -M -s /sbin/nologin  mysql
 ​
 #解压软件包
 cd /opt
 tar xzvf mysql-boost-5.7.20.tar.gz -C /opt
 ​
 #指定安装路径和安装模块
 cd /opt/mysql-5.7.20/
 cmake \
 -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
 -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
 -DSYSCONFDIR=/etc \
 -DSYSTEMD_PID_DIR=/usr/local/mysql \
 -DDEFAULT_CHARSET=utf8  \
 -DDEFAULT_COLLATION=utf8_general_ci \
 -DWITH_EXTRA_CHARSETS=all \
 -DWITH_INNOBASE_STORAGE_ENGINE=1 \
 -DWITH_ARCHIVE_STORAGE_ENGINE=1 \
 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
 -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
 -DMYSQL_DATADIR=/usr/local/mysql/data \
 -DWITH_BOOST=boost \
 -DWITH_SYSTEMD=1
 ​
 #编译及安装,开2核编译,注意虚拟机的处理器数量要设置为2
 make -j 2 && make install
 ​
 #修改mysql 配置文件
 echo '[client]
 port = 3306
 socket=/usr/local/mysql/mysql.sock
 ​
 [mysqld]
 user = mysql
 basedir=/usr/local/mysql
 datadir=/usr/local/mysql/data
 port = 3306
 character-set-server=utf8
 pid-file = /usr/local/mysql/mysqld.pid
 socket=/usr/local/mysql/mysql.sock
 bind-address = 0.0.0.0
 skip-name-resolve
 max_connections=2048
 default-storage-engine=INNODB
 max_allowed_packet=16M
 server-id = 1
 ​
 sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES' > /etc/my.cnf
 ​
 ​
 #更改mysql安装目录和配置文件的属主属组
 chown -R mysql:mysql /usr/local/mysql/
 chown mysql:mysql /etc/my.cnf
 ​
 #将mysql的可执行文件放入环境变量PATH的目录中,方便系统直接识别mysql命令
 cp /usr/local/mysql/bin/* /usr/bin/
 cp /usr/local/mysql/lib/* /usr/bin/
 ​
 ​
 #初始化数据库
 cd /usr/local/mysql/bin/
 ./mysqld \
 --initialize-insecure \
 --user=mysql \
 --basedir=/usr/local/mysql \
 --datadir=/usr/local/mysql/data
 ​
 #添加mysqld系统服务
 cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/ 
 ​
 #重新加载,启动mysql服务,将mysql设置为开机自启
 systemctl daemon-reload
 systemctl start mysqld.service
 systemctl enable mysqld
 ​
 #修改mysql 的登录密码
 function mima {
 /usr/bin/expect <<-EOF
 pass=$1
 spawn mysqladmin -u root -p password $pass
 expect "Enter password:" {send "\r"}
 EOF
 }
 mima abc123
 ​
 #授权远程登录mysql数据库
 #授予root用户可以在所有终端远程登录,使用的密码是abc123,并对所有数据库和所有表有操作权限。
 function shouquan {
 /usr/bin/expect <<-EOF
 spawn mysql -u root -p
 expect " Enter password: " {send "abc123\n"}
 expect "mysql>" {send "grant all privileges on *.* to 'root'@'%' identified by 'abc123';\n"}
 expect "mysql>" {send "quit\n"}
 EOF
 }
 shouquan

编译安装 PHP 解析环境

写一个一键安装PHP解析环境的脚本

 #=====PHP=======
 #安装环境依赖包
 rm -f /var/run/yum.pid
 yum install -y gd \
 libjpeg libjpeg-devel \
 libpng libpng-devel \
 freetype freetype-devel \
 libxml2 libxml2-devel \
 zlib zlib-devel \
 curl curl-devel \
 openssl openssl-devel
 ​
 #如果yum安装失败,则退出脚本
 [ $? != 0 ] && exit
 ​
 #解压软件包
 cd /opt
 tar xjvf php-7.1.10.tar.bz2 -C /opt
 ​
 #指定安装路径和安装
 cd php-7.1.10
 ./configure \
 --prefix=/usr/local/php \
 --with-mysql-sock=/usr/local/mysql/mysql.sock \
 --with-mysqli \
 --with-zlib \
 --with-curl \
 --with-gd \
 --with-jpeg-dir \
 --with-png-dir \
 --with-freetype-dir \
 --with-openssl \
 --enable-fpm \
 --enable-mbstring \
 --enable-xml \
 --enable-session \
 --enable-ftp \
 --enable-pdo \
 --enable-tokenizer \
 --enable-zip
 ​
 #编译及安装,开2核编译,注意虚拟机的处理器数量要设置为2
 make -j 2 && make install
 ​
 #路径优化。将php的所有可执行文件,放入环境变量PATH的目录下,便于系统识别
 ln -s /usr/local/php/bin/* /usr/local/bin/
 ln -s /usr/local/php/sbin/* /usr/local/sbin/
 ​
 #php有三个配置文件: 
 #php.ini 主配置文件
 #php-fpm.conf 进程服务配置文件
 #www.conf 扩展配置文件
 ​
 #调整主配置文件:php.ini
 #复制模版文件作为PHP的主配置文件,并进行修改。在测试环境时使用php.ini-development文件,而在生产环境时使用php.ini-production文件。
 cp /opt/php-7.1.10/php.ini-development /usr/local/php/lib/php.ini
 #修改第1170行
 sed -i '1170c mysqli.default_socket = /usr/local/mysql/mysql.sock' /usr/local/php/lib/php.ini
 #修改第939行
 sed -i '939c date.timezone = Asia/Shanghai' /usr/local/php/lib/php.ini
 ​
 #验证安装的模块
 php -m 
 ​
 #进程服务配置文件:php-fpm.conf
 cd /usr/local/php/etc/
 cp php-fpm.conf.default php-fpm.conf
 #修改第17行
 sed -i '17c pid = run/php-fpm.pid' /usr/local/php/etc/php-fpm.conf
 ​
 #扩展配置文件:www.conf
 cd /usr/local/php/etc/php-fpm.d/
 cp www.conf.default www.conf
 ​
 #启动php-fpm
 ln -s /usr/local/php/sbin/* /usr/local/sbin
 /usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini
 netstat -anpt | grep 9000
 ​
 #PHP-FPM(FastCGI Process Manager:FastCGI 进程管理器)是一个 PHPFastCGI 管理器, 由于Nginx服务器不能处理动态页面,需要由 Nginx 把动态请求交给 php-fpm 进程进行解析。
 cd /opt/php-7.1.10/sapi/fpm
 cp php-fpm.service /usr/lib/systemd/system/php-fpm.service
 systemctl restart php-fpm.service
 ​
 ​
 #配置 Nginx 支持 PHP 解析
 #--65行--取消注释,修改
 sed -i '65c location ~ .php$ {' /usr/local/nginx/conf/nginx.conf
 sed -i '66c root  html;' /usr/local/nginx/conf/nginx.conf
 sed -i '67c fastcgi_pass   127.0.0.1:9000;' /usr/local/nginx/conf/nginx.conf
 sed -i '68c fastcgi_index  index.php;' /usr/local/nginx/conf/nginx.conf
 #将 /scripts 修改为nginx的工作目录
 sed -i '69c fastcgi_param  SCRIPT_FILENAME  /usr/local/nginx/html$fastcgi_script_name;' /usr/local/nginx/conf/nginx.conf
 sed -i '70c include  fastcgi_params;' /usr/local/nginx/conf/nginx.conf
 sed -i '71c }' /usr/local/nginx/conf/nginx.conf
 systemctl restart nginx.service
 ​
 #验证PHP 测试页
 echo '<?php
 phpinfo();
 ?>' > /usr/local/nginx/html/index.php
 ​
 ​
 #验证数据库工作是否正常
 function yanzheng {
 /usr/bin/expect <<-EOF
 spawn mysql -u root -p
 expect " Enter password: " {send "abc123\n"}
 expect "mysql>" {send "CREATE DATABASE bbs;\r"}
 #把bbs数据库里面所有表的权限,授予给所有主机的bbsuser,使用的密码是abc123。
 expect "mysql>" {send "GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'abc123';\r"}
 #把bbs数据库里面所有表的权限,授予给本地的bbsuser,使用的密码是admin123。localhost使用的是本地回环地址127.0.0.1进行访问。
 expect "mysql>" {send "GRANT all ON bbs.* TO 'bbsuser'@'localhost' IDENTIFIED BY 'abc123';\r"}
 #刷新数据库
 expect "mysql>" {send "flush privileges;\r"}
 expect "mysql>" {send "quit\r"}
 EOF
 }
 yanzheng

部署Discuz社区论坛

写一个一键部署Discuz社区论坛的脚本

 #部署Discuz社区论坛
 ​
 #创建一个新的数据库bbs,并进行授权
 function crebbs {
 /usr/bin/expect <<-EOF
 spawn mysql -u root -p
 expect " Enter password: " {send "abc123\n"}
 expect "mysql>" {send "CREATE DATABASE bbs;\r"}
 #把bbs数据库里面所有表的权限,授予给所有主机的bbsuser,使用的密码是abc123。
 expect "mysql>" {send "GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'abc123';\r"}
 #把bbs数据库里面所有表的权限,授予给本地的bbsuser,使用的密码是admin123。localhost使用的是本地回环地址127.0.0.1进行访问。
 expect "mysql>" {send "GRANT all ON bbs.* TO 'bbsuser'@'localhost' IDENTIFIED BY 'abc123';\r"}
 #刷新数据库
 expect "mysql>" {send "flush privileges;\r"}
 expect "mysql>" {send "quit\r"}
 EOF
 }
 crebbs
 ​
 ​
 #解压安装包,因为是.zip格式,所以使用unzip命令进行解压
 cd /opt
 unzip Discuz_X3.4_SC_UTF8.zip  -d /opt/dis
 cd /opt/dis/dir_SC_UTF8/
 cp -r upload/ /usr/local/nginx/html/bbs/
 ​
 #调整论坛目录的权限
 cd /usr/local/nginx/html/bbs/
 chown -R nginx ./config/
 chown -R nginx ./data/
 chown -R nginx ./uc_client/
 chown -R nginx ./uc_server/
 ​
 chmod -R 777 ./config/
 chmod -R 777 ./data/
 chmod -R 777 ./uc_client/
 chmod -R 777 ./uc_server/
 ​
 ​
 #获取本机IP地址
 ip=`ifconfig ens33 | awk 'NR==2{print $2}'`
 ​
 echo -e "\033[31m 此时可访问:$ip/index.php \033[0m"
 echo -e "\033[31m 此时可进入浏览器安装论坛:http://$ip/bbs/install/index.php \033[0m"
 echo -e "\033[31m 数据库服务器:localhost \033[0m"     
 echo -e "\033[31m 数据库名字:bbs \033[0m"
 echo -e "\033[31m 数据库用户名:bbsuser \033[0m"
 echo -e "\033[31m 数据库密码:abc123 \033[0m"
 echo -e "\033[31m 管理员账号:admin \033[0m"
 echo -e "\033[31m 管理员密码:abc123 \033[0m"
 echo -e "\033[31m 论坛内部页面:http://$ip/bbs/index.php \033[0m"
 echo -e "\033[31m 论坛后台管理员页面:http://$ip/bbs/admin.php \033[0m"

执行五个脚本,安装完成后使用浏览器访问验证

您好!对于一键部署 LNMP(Linux + Nginx + MySQL + PHP)环境,可以使用 Ansible 来自动化部署。Ansible 是一种配置管理工具,可以通过编写 YAML 或 JSON 格式的配置文件来描述所需的部署步骤。 下面是一个简单的 Ansible playbook 示例,用于一键部署 LNMP 环境: ```yaml --- - name: Deploy LNMP hosts: your_servers become: yes tasks: - name: Install dependencies apt: name: - nginx - mysql-server - php-fpm state: latest - name: Configure Nginx template: src: nginx.conf.j2 dest: /etc/nginx/nginx.conf - name: Start Nginx service: name: nginx state: started enabled: yes - name: Configure MySQL template: src: my.cnf.j2 dest: /etc/mysql/my.cnf - name: Start MySQL service: name: mysql state: started enabled: yes - name: Configure PHP-FPM template: src: php-fpm.conf.j2 dest: /etc/php/7.4/fpm/php-fpm.conf - name: Start PHP-FPM service: name: php-fpm state: started enabled: yes ``` 在上面的示例中,您需要将 `your_servers` 替换为目标服务器的 IP 地址或主机名。该 playbook 的任务包括安装依赖软件包、配置 Nginx、MySQL 和 PHP-FPM,以及启动相应的服务。 您还需要编写对应的模板文件,例如 `nginx.conf.j2`、`my.cnf.j2` 和 `php-fpm.conf.j2`,用于生成配置文件。这些模板文件中可以包含您自定义的配置内容。 通过运行以下命令来执行 Ansible playbook: ```shell ansible-playbook deploy_lnmp.yml ``` 以上是一个简单的示例,您可以根据实际需求进行修改和扩展。希望对您有帮助!如有更多问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值