89291041 2019-11-04
由于工作的原因,需要经常搭建 LNMP(PHP7+MySQL5.7+Nginx)的环境,虽然网上有不少教程,但是目前为止还没有找到一个完成符合我的教程,所以每次部署环境的时候都是打开几个教程进行部署的,所以还是挺麻烦的,今天也是抽点时间归纳一下教程。
[root@localhost ~]# rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm [root@localhost ~]# rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm [root@localhost ~]# rpm -Uvh http://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm
[root@localhost ~]# yum -y install nginx [root@localhost ~]# yum -y install mysql-community-server [root@localhost ~]# yum -y install php72w php72w-devel php72w.x86_64 php72w-cli.x86_64 php72w-common.x86_64 php72w-gd.x86_64 php72w-ldap.x86_64 php72w-mbstring.x86_64 php72w-mcrypt.x86_64 php72w-pdo.x86_64 php72w-mysqlnd php72w-fpm php72w-opcache php72w-pecl-redis php72w-pecl-mongo php72w-mcrypt
MySQL 安装完成之后,在/var/log/mysqld.log 文件中给出 root 生成一个 默认密码。
[root@localhost ~]# systemctl start mysqld # 启动 MySQL [root@localhost ~]# grep 'temporary password' /var/log/mysqld.log # 查找默认密码 2017-04-10T02:58:16.806931Z 1 [Note] A temporary password is generated for root@localhost: iacFXpWt-6gJ
[root@localhost ~]# mysql -uroot -p'iacFXpWt-6gJ'
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyPass1!';
mysql> set password for 'root'@'localhost'=password('123abc');
详见 MySQL 官网密码策略详细说明:https://dev.mysql.com/doc/ref...
[root@localhost ~]# systemctl enable mysqld
[root@localhost ~]# systemctl restart mysqld
默认配置文件路径:
配置文件:/etc/my.cnf
日志文件:/var/log/mysqld.log
服务启动脚本:/usr/lib/systemd/system/mysqld.service
socket 文件:/var/run/mysqld/mysqld.pid
[root@localhost ~]# systemctl status firewalld
[root@localhost ~]# firewall-cmd --zone=public --add-port=80/tcp --permanent [root@localhost ~]# firewall-cmd --zone=public --add-port=443/tcp --permanent
出现 success 表明添加成功
--zone #作用域
--add-port=80/tcp #添加端口,格式为:端口/通讯协议
--permanent #永久生效,没有此参数重启后失效
[root@localhost ~]# systemctl enable nginx
在server { } 里添加:
location / { #定义首页索引文件的名称 index index.php index.html index.htm; } # PHP 脚本请求全部转发到 FastCGI处理. 使用FastCGI默认配置. location ~ .php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; }
[root@localhost ~]# systemctl start nginx # 启动 Nginx
[root@localhost ~]# systemctl enable php-fpm [root@localhost ~]# systemctl start php-fpm # 启动 php-fpm
至此,LNMP 的环境就已经搭建好了。
swoole 扩展是按照 PHP 标准扩展构建的。使用 phpize 来生成编译检测脚本,./configure 来做编译配置检测,make 进行编译,make install 进行安装。
安装前必须保证系统已经安装了下列软件
[root@localhost ~]# yum -y install postgresql-devel [root@localhost ~]# yum install glibc-headers gcc-c++ git-core gcc autoconf cmake libcurl4-openssl-dev openssl libssl-dev build-essential zlibc zlib-bin libidn11-dev libidn11 minizip openssl-devel
[root@localhost ~]# wget http://pecl.php.net/get/swoole-4.2.6.tgz [root@localhost ~]# tar -zxvf swoole-4.2.6
下载源码包后,在终端进入源码目录,执行下面的命令进行编译和安装
[root@localhost ~]# cd swoole-4.2.6 [root@localhost ~]# phpize (ubuntu 没有安装phpize可执行命令:sudo apt-get install php-dev来安装phpize) [root@localhost ~]# ./configure [root@localhost ~]# make [root@localhost ~]# make install
初次接触swoole的开发者请先尝试上方简单编译,如果有进一步的需求和本本,调整一下示例的编译参数
https://wiki.swoole.com/wiki/page/6.html
注意:PECL 发布时间晚于 Github 发布时间
Swoole 项目已收录到 PHP 官方扩展库,除了手工下载编译外,还可以通过 PHP 官方的 pecl 命令,一键下载安装
[root@localhost ~]# pecl install swoole
安装过程中需要根据自己的情况进行配置,如果没有清晰的思路,可以全部选为yes。
编译安装成功后,修改php.ini 加入
extension=swoole.so
或者
在 /etc/php.d/下新建并并写入 # vim /etc/php.d/swoole.ini ; Enable swoole extension module extension=swoole.so
通过php -m或phpinfo()来查看是否成功加载了swoole.so,如果没有可能是php.ini的路径不对,可以使用php --ini来定位到php.ini的绝对路径。
在开发调试的环境中,通常需要利用数据库管理软件进行管理数据库,所以需要添加数据库的远程连接。
[root@localhost ~]# mysql -uroot -p
[root@localhost ~]# use mysql; [root@localhost ~]# select host, user from user;
查询结果为127.0.0.1或者localhost或者当前服务器域名,则表示不允许远程连接。
[root@localhost ~]# GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'IDENTIFIED BY '111qqqpwd' WITH GRANT OPTION; [root@localhost ~]# FLUSH PRIVILEGES;
[root@localhost ~]# firewall-cmd --list-port
[root@localhost ~]# firewall-cmd --zone=public --add-port=3306/tcp --permanent
[root@localhost ~]# systemctl restart firewalld
https://segmentfault.com/a/1190000009012613
https://www.cnblogs.com/hello-tl/p/9404655.html
https://my.oschina.net/sokes/blog/826705
https://wiki.swoole.com/wiki/page/6.html