1、关闭防火墙,将安装nginx所需软件包传到/opt目录下
一、安装 Nginx 服务
1、关闭防火墙,将安装Nginx所需软件包传到/opt目录下
systemctl stop firewalld systemctl disable firewalld setenforce 0
yum install -y pcre-devel zlib-devel gcc gcc-c++ make
#Nginx的配置及运行需要pcre、zlib等软件包的支持,因此需要安装这些安装的开发包,以便提供相应的库和头文件
3、创建运行用户、组
useradd -M -s /sbin/nologin Nginx #Nginx服务程序默认以nobody身份运行,建议为其创建专门的用户账号,以便更准确地控制其访问权限
4、编译安装Nginx
cd /opt tar zxvf Nginx-1.12.0.tar.gz cd Nginx-1.12.0/ ./configure \ > --prefix=/usr/local/Nginx \ #指定Nginx的安装路径 > --user=Nginx \ #指定用户名 > --group=Nginx \ #指定组名 > --with-http_stub_status_module #启用 http_stub_status_module模块以变持状态线计 make && make install ln -s /usr/local/Nginx/sbin/Nginx /usr/local/sbin/ #让系统识别Nginx的操作命令
vim /lib/systemd/system/Nginx.service [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 SMAINPID ExecrStop=/bin/kill-s QUIT $MAINPID PrivateTmp=true [Install] WantedBy=multi-user.target chmod 754 /lib/systemd/ system/Nginx.service systemctl start Nginx.service systemctl enable Nginx.service
二、安装 MysqL 服务
1、安装MysqL环境依赖包
yum -y install \ ncurses \ ncurses-devel \ bison \ cmake
2、创建运行用户
useradd -M -s /sbin/nologin MysqL
cd /opt tar zxvf MysqL-boost-5.7.20.tar.gz 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 make && make install
vim /etc/my.cnf [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
chown -R MysqL:MysqL /usr/local/MysqL/ chown MysqL:MysqL /etc/my.cnf
echo 'export PATH=/usr/local/MysqL/bin:/usr/local/MysqL/lib:$PATH' >> /etc/profile source /etc/profile
7、初始化数据库
cd /usr/local/MysqL/bin/ ./MysqLd \ --initialize-insecure \ --user=MysqL \ --basedir=/usr/local/MysqL \ --datadir=/usr/local/MysqL/data
cp /usr/local/MysqL/usr/lib/systemd/system/MysqLd.service /usr/lib/systemd/system/ systemctl daemon-reload systemctl start MysqLd.service systemctl enable MysqLd
MysqLadmin -u root -p password "112233"
10、授权远程登录
MysqL -u root -p grant all privileges on *.* to 'root'@'%' identified by '112233'; #授予root用户可以在所有终端远程登录,使用的密码是112233,并对所有数据库和所有表有操作权限 show databases; #查看当前已有的数据库
三、编译安装PHP
yum -y install gd \ libjpeg libjpeg-devel \ libpng libpng-devel \ freetype freetype-devel \ libxml2 libxml2-devel \ zlib zlib-devel \ curl curl-devel \ openssl openssl-devel
cd /opt tar jxvf PHP-7.1.10.tar.bz2 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 make && make install
ln -s /usr/local/PHP/sbin/* /usr/local/sbin/
#调整主配置文件: cp /opt/PHP-7.1.10/PHP.ini-development /usr/local/PHP/lib/PHP.ini vim /usr/local/PHP/lib/PHP.ini --1170行--修改 MysqLi.default_socket = /usr/local/MysqL/MysqL.sock --939行--取消注释,修改 date.timezone = Asia/Shanghai PHP -m #验证安装的模块
#调整进程服务配置文件: cd /usr/local/PHP/etc/ cp PHP-fpm.conf.default PHP-fpm.conf vim PHP-fpm.conf --17行--去掉";"注释 pid = run/PHP-fpm.pid
(3)www.conf扩展配置文件
#调整扩展配置文件: cd /usr/local/PHP/etc/PHP-fpm.d/ cp www.conf.default www.conf
5、启动PHP-fpm
/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
vim /usr/local/Nginx/conf/Nginx.conf --65行--取消注释,修改 location ~ \.PHP$ { root html; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.PHP; fastcgi_param SCRIPT_FILENAME /usr/local/Nginx/html$fastcgi_script_name; #将 /scripts 修改为Nginx的工作目录 include fastcgi_params; } systemctl restart Nginx.service
vim /usr/local/Nginx/html/index.PHP <?PHP PHPinfo(); ?> 浏览器访问 http://192.168.142.4/index.PHP
8、验证数据库工作是否正常
MysqL -u root -p CREATE DATABASE bbs; #创建bbs数据库 GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY '112233'; #指定可以使用的用户 GRANT all ON bbs.* TO 'bbsuser'@'localhost' IDENTIFIED BY '112233'; flush privileges; #刷新数据库 vim /usr/local/Nginx/html/index.PHP #替换原来的测试页内容 <?PHP $link=MysqLi_connect('192.168.142.4','bbsuser','admin123'); if($link) echo "<h1>Success!!</h1>"; else echo "Fail!!"; ?> 浏览器访问 http://192.168.142.4/index.PHP
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。