LNMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写。L指Linux,N指Nginx,M一般指MySQL,也可以指MariaDB,P一般指PHP,也可以指Perl或Python
LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构。 Linux是一类Unix计算机操作系统的统称,是目前最流行的免费操作系统。代表版本有:debian、centos、ubuntu、fedora、gentoo等。
Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器。
Mysql是一个小型关系型数据库管理系统。
PHP是一种在服务器端执行的嵌入HTML文档的脚本语言。
这四种软件均为免费开源软件,组合到一起,成为一个免费、高效、扩展性强的网站服务系统
环境安装
1.挂载宿主机的共享文件夹,读取下载好的源码文件 2.解压跨平台组件包和源码包 将跨平台组件包移动到源码包目录下 3.安装编译器和其他工具
yum -y install gcc \ gcc-c++ \ make \ pcre-devel \ expat-devel \ perl \ zlib-devel \ pcreconfigure配置
./configure \ --prefix=/usr/local/nginx \ --user=nginx \ --group=nginx \ --with-http_stub_status_modulemake编译和make install
make && make install路径优化
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin '//nginx命令执行路径优化' useradd -M -s /sbin/nologin nginx使用systemctl控制
vim /lib/systemd/system/nginx.service '//添加使用systemctl工具进行管理' [Unit] Description=nginx '//描述' After=network.target '//描述服务类别' [Service] Type=forking '//后台运行形势' PIDFile =/usr/local/nginx/logs/nginx.pid '//PID文件位置' ExecStart=/usr/local/nginx/sbin/nginx '//启动服务' ExecReload=/usr/bin/kill -S HUP $MAINPID '//根据PID重载配置' ExecStop=/usr/bin/kill -S QUIT $MAINPID '//根据PID终止进程' PrivateTmp=true [Install] WantedBy=multi-user.target chmod 754 /lib/systemd/system/nginx.service开启nginx,关闭防火墙
chmod +754 nginx.service systemctl start nginx.service netstat -ntap |grep 80 tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 5396/nginx: master tcp 0 0 192.168.197.192:56680 192.168.100.3:445 ESTABLISHED - systemctl stop firewalld.service setenforce 0安装mysql环境依赖包
yum -y install \ ncurses \ '//字符终端的包,方便终端操作' ncurses-devel \ bison \ '//函数库' cmake '//没有configure,使用cmake' 创建用户 useradd -s /usr/sbin/nologin mysqlcmake配置和make和make install
解压mysql-boost-5.7.20.tar.gz到opt目录下 '//boost是5.7版本的特性' 进入mysql1-57.20目录 cmake \ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ '//sock;通讯文件,连接数据库,通讯协议的载体' -DSYSCONFDIR=/etc \ '//配置目录指向etc' -DSYSTEMD_PID_DIR=/usr/local/mysql \ '//pid文件位置' -DDEFAULT_CHARSET=utf8 \ '//此行和下一行为字符集相关' -DDEFAULT_COLLATION=utf8_general_ci \ -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 \ '//指定boost位置' -DWITH_SYSTEMD=1 '//守护进程'make & make install 设置/usr/local/mysql目录的权限
chown -R mysql.mysql /usr/local/mysql编辑配置文件
cd /etc vim my.cnf '//将内容全部删除,添加以下内容' [client] port = 3306 default-character-set=utf8 socket = /usr/local/mysql/mysql.sock [mysql] port = 3306 default-character-set=utf8 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 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设置环境变量
echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile echo 'export PATH' >> /etc/profile source /etc/profile初始化数据库
cd /usr/local/mysql/ 执行 bin/mysqld \ --initialize-insecure \ --user=mysql \ --basedir=/usr/local/mysql \ --datadir=/usr/local/mysql/data cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/开启数据库,检查状态
systemctl enable mysqld systemctl start mysqld systemctl stop mysqld systemctl status mysqld netstat -ntap |grep mysqld '//应该查出来3306端口'设置mysql密码
mysqladmin -u root -p password '//刚开始没密码是空的直接回车,然后输入密码abe123,再次确认密码'尝试登录数据库
mysql -u root -p '//这个命令敲下,提示要输入密码,这个就是刚才设置的密码abc123'安装环境包
yum -y install \ libjpeg \ libjpeg-devel \ libpng libpng-devel \ freetype freetype-devel \ libxml2 \ libxml2-devel \ zlib zlib-devel \ curl curl-devel \ openssl openssl-devel编译安装
cd /opt tar xjvf php-7.1.10.tar.bz2 '//将下载的软件包解压到/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-zipmake && make install 配置PHP的三个配置文件
'//php有三个配置文件 php.ini核心配置文件 php-fpm.conf进程服务配置文件www.conf 扩展配置文件' cp php.ini-development /usr/local/php/lib/php.ini vi /usr/local/php/lib/php.ini '//找到以下两行的位置,修改这两行' mysql.default_socket = /usr/local/mysql/mysql.sock date.timezone = Asia/Shanghai '//找到后,前方的;注释要去掉' /usr/local/php/bin/php -m/验证安装的模块创建软链接
/usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini netstat -natp |grep 9000 tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 32236/php-fpm: mast ln -s /usr/local/php/bin/* /usr/local/bin/ ps aux | grep -c "php-fpm”//结果 ln -s /usr/local/php/bin/* /usr/local/bin/ ps aux |grep -c "php-fpm" 4编辑,让nginx支持PHP功能
vi /usr/local/nginx/conf/nginx.conf //找到下面字段 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; include fastcgi_params; } '//用/usr/local/nginx/html替换原来的路径 vi /usr/local/nginx/html/index.php <?php phpinfo(); ?> systemctl restart nginx测试数据库工作是否正常
mysq1 -u root -p ##输入abc123密码 CREATE DATABASE bbs; GRANT all ON bbs.* To 'bbsuser'@'%' IDENTIFIED BY 'admin123'; GRANT all ON bbs.* To 'bbsuser'@'localhost' IDENTIFIED BY 'admin123'; flush privileges; vi /usr/local/nginx/html/index.php ###原来的测试页内容更改如下 <?php $link=mysqli_connect('192.168.197.192','bbsuser','admin123'); if($link) echo"<h1>Success!!</h1>"; else echo "Fail!!"; ?> systemctl restart nginx 在网页测试http://192.168.197.192/index.php