LNMP 环境搭建

9 篇文章 0 订阅
4 篇文章 0 订阅

LNMP 环境搭建

安装所需软件环境

yum -y install gcc automake autoconf libtool make yum -y install gcc gcc-c++ glibc yum -y install libmcrypt-devel mhash-devel libxslt-devel \ libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml 2-devel \ zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel \ ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel \ krb5 krb5-devel libidn libidn-devel openssl openssl-devel

注意:如果使用的光盘源,上面的 libmcrypt 可能安装失败

 

wget http://softlayer.dl.sourceforge.net/sourceforge/mcrypt/libmcrypt-2.5.8.tar. gz tar -zxvf libmcrypt-2.5.8.tar.gz cd /usr/local/src/libmcrypt-2.5.8 ./configure --prefix=/usr/local/libmcrypt make make install

安装 php

./configure --prefix=/usr/local/lnmp/php --enable-fpm --with-mcrypt --enable-m bstring --disable-pdo --with-curl --disable-debug --disable-rpath --enable-inli ne-optimization --with-bz2 --with-zlib --enable-sockets --enable-sysvsem --enab le-sysvshm --enable-pcntl --enable-mbregex --with-mhash --enable-zip --with-pcr e-regex --with-mysql --with-mysqli --with-gd --with-jpeg-dir make && make install

安装 nginx

 

yum -y install pcre-devel ./configure --prefix=/usr/local/lnmp/nginx --conf-path=/usr/local/lnmp/nginx/co nf/nginx.conf --sbin-path=/usr/local/lnmp/nginx/nginx --error-log-path=/var/log /nginx/error.log --pid-path=/var/run/nginx/nginx.pid --lock-path=/var/lock/ngin x.lock --user=nginx --group=nginx --with-http_ssl_module --with-http_gzip_stat ic_module --http-log-path=/var/log/nginx/access.log --http-client-body-temp-pat h=/var/tmp/nginx/client --http-proxy-temp-path=/var/tmp/nginx/proxy --http-fast cgi-temp-path=/var/tmp/nginx/fcgi --with-http_stub_status_module make && make install

添加用户和组

groupadd -r nginx useradd -g nginx -s /sbin/nologin -r nginx

检查配置文件

 

/usr/local/nginx/nginx -t

创建所需目录

mkdir /var/tmp/nginx/client -p

安装启动文件

配置 php-fpm

 

cd /usr/local/lnmp/php cp etc/php-fpm.conf.default etc/php-fpm.conf vi etc/php-f pm.conf user = www-data; group=www-data;

添加用户和组

如果 www-data 用户不存在,那么先添加 www-data 用户

groupadd www-data -r useradd -g www-data www-data -r -s /sbin/nologin

启动 php-fpm 和 nginx

 

/usr/local/lnmp/php/sbin/php-fpm /usr/local/lnmp/nginx/nginx

常见错误

如果遇到访问 php 文件时,提示 file not found,修改 nginx.conf

fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name

另外需要保证 php-fpm 的用户有代码文件的 xr 权限


mysql 安装

 

yum -y install cmake tar zxf mysql-5.6.25.tar.gz cd mysql-5.6.25 cmake -DCMAKE_INSTALL_PREFIX=/usr/local/lnmp/mysql \ -DMYSQL_UNIX_ADDR=/tmp/mysql.sock \ -DDEFAULT_CHARSET=utf8 \ -DDEFAULT_COLLATION=utf8_general_ci \ -DWITH_EXTRA_CHARSETS:STRING=utf8,gbk \ -DWITH_MYISAM_STORAGE_ENGINE=1 \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_READLINE=1 \ -DENABLED_LOCAL_INFILE=1 \ -DMYSQL_DATADIR=/usr/local/lnmp/mysql/data \ -DMYSQL_USER=mysql make && make install

添加用户

groupadd -r mysql useradd -g mysql -s /sbin/nologin -r mysql

修改目录权限,将所有者改为 mysql

 

chown mysql.mysql /usr/local/lnmp/mysql/data -R

复制配置文件

cp support-files/my-default.cnf /etc/my.cnf

创建 mysql 测试数据库和系统数据库

 

/usr/local/lnmp/mysql/scripts/mysql_install_db --user=mysql --datadir=/usr/local/lnmp/mysql/data

复制启动文件,便于通过 service 管理

cp /usr/local/lnmp/mysql/support-files/mysql.server /etc/init.d/mysqld # 复制启动文件 chmod +x /etc/init.d/mysqld

开机自启动

 

chkconfig --add mysqld chkconfig --level 345 mysqld on

启动 mysql

service mysqld start


yum 安装 nginx

nginx 不在官方源中,先执行

 

rpm -Uvh http://dl.fedoraproject.org/pub/epel/5/i386/epel-release-5-4.noarch.rpm

安装

yum -y install nginx

提示 libgd.so.2 找不到,需要到 http://pkgs.org/download/libgd.so.2 下载

(http://pkgs.org/centos-5/atrpms-testing-i386/libgd2-2.0.33-2_11.0.el5.i386.rpm/download/)

 

wget http://dl.atrpms.net/el5-i386/atrpms/testing/libgd2-2.0.33-2_11.0.el5.i386. rpm rpm -ivh libgd2-2.0.33-2_11.0.el5.i386.rpm

拷贝 nginx 启动脚本(/etc/init.d/nginx),修改备份

20180308-1-nginx-1.png

20180308-1-nginx-2.png

最终脚本(右键保存到文件):

有了这个脚本以后不用 yum 安装了,使用这个就有服务控制程序了


移动到服务目录

将上面的脚本移动到/etc/init.d 目录下,然后添加 x 权限

现在可以使用:service nginx 命令了


防火墙设置

使用下面命令打开 80 端口

sudo /sbin/iptables -I RH-Firewall-1-INPUT 1 -p tcp --dport http -j ACCEPT sudo /sbin/service iptables save

启动 nginx

 

/etc/init.d/nginx start

nginx 编译安装参数详解

内容有些多,一眼看来难免头昏脑胀,但坚持看完,相信你一定会有所收获。

nginx 参数:

 

--prefix= 指向安装目录 --sbin-path 指向(执行)程序文件(nginx) --conf-path= 指向配置文件(nginx.conf) --error-log-path= 指向错误日志目录 --pid-path= 指向 pid 文件(nginx.pid) --lock-path= 指向 lock 文件(nginx.lock)(安装文件锁定,防止安装文件被别人利用,或自己误操作。) --user= 指定程序运行时的非特权用户 --group= 指定程序运行时的非特权用户组 --builddir= 指向编译目录 --with-rtsig_module 启用 rtsig 模块支持(实时信号) --with-select_module 启用 select 模块支持(一种轮询模式,不推荐在高载环境下使用) 禁用:--without-select_module --with-poll_module 启用 poll 模块支持(功能与 select 相同,与 select 特性相同,为一种轮询模式,不推荐在高载环境下使用) --with-file-aio 启用 file aio 支持(一种 APL 文件传输格式) --with-ipv6 启用 ipv6 支持 --with-http_ssl_module 启用 ngx_http_ssl_module 支持(使支持 https 请求,需已安装openssl) --with-http_realip_module 启用 ngx_http_realip_module 支持(这个模块允许从请求标头更改客户端的 IP 地址值,默认为关) --with-http_addition_module 启用 ngx_http_addition_module 支持(作为一个输出过滤器,支持不完全缓冲,分部分响应请求) --with-http_xslt_module 启用 ngx_http_xslt_module 支持(过滤转换 XML 请求) --with-http_image_filter_module 启用 ngx_http_image_filter_module 支持(传输JPEG/GIF/PNG 图片的一个过滤器)(默认为不启用。gd 库要用到) --with-http_geoip_module 启用 ngx_http_geoip_module 支持(该模块创建基于与MaxMind GeoIP 二进制文件相配的客户端 IP 地址的 ngx_http_geoip_module 变量) --with-http_sub_module 启用 ngx_http_sub_module 支持(允许用一些其他文本替换nginx 响应中的一些文本) --with-http_dav_module 启用 ngx_http_dav_module 支持(增加 PUT,DELETE,MKCOL:创建集合,COPY 和 MOVE 方法)默认情况下为关闭,需编译开启 --with-http_flv_module 启用 ngx_http_flv_module 支持(提供寻求内存使用基于时间的偏移量文件) --with-http_gzip_static_module 启用 ngx_http_gzip_static_module 支持(在线实时压缩输出数据流) --with-http_random_index_module 启用 ngx_http_random_index_module 支持(从目录中随机挑选一个目录索引) --with-http_secure_link_module 启用 ngx_http_secure_link_module 支持(计算和检查要求所需的安全链接网址) --with-http_degradation_module 启用 ngx_http_degradation_module 支持(允许在内存不足的情况下返回 204 或 444 码) --with-http_stub_status_module 启用 ngx_http_stub_status_module 支持(获取 nginx自上次启动以来的工作状态) --without-http_charset_module 禁用 ngx_http_charset_module 支持(重新编码 web页面,但只能是一个方向--服务器端到客户端,并且只有一个字节的编码可以被重新编码) --without-http_gzip_module 禁用 ngx_http_gzip_module 支持(该模块同 -with-http_gzip_static_module 功能一样) --without-http_ssi_module 禁用 ngx_http_ssi_module 支持(该模块提供了一个在输入端处理处理服务器包含文件(SSI)的过滤器,目前支持 SSI 命令的列表是不完整的) --without-http_userid_module 禁用 ngx_http_userid_module 支持(该模块用来处理用来确定客户端后续请求的 cookies) --without-http_access_module 禁用 ngx_http_access_module 支持(该模块提供了一个简单的基于主机的访问控制。允许/拒绝基于 ip 地址) --without-http_auth_basic_module 禁用 ngx_http_auth_basic_module(该模块是可以使用用户名和密码基于 http 基本认证方法来保护你的站点或其部分内容) --without-http_autoindex_module 禁用 disable ngx_http_autoindex_module 支持(该模块用于自动生成目录列表,只在 ngx_http_index_module 模块未找到索引文件时发出请求。) --without-http_geo_module 禁用 ngx_http_geo_module 支持(创建一些变量,其值依赖于客户端的 IP 地址) --without-http_map_module 禁用 ngx_http_map_module 支持(使用任意的键/值对设置配置变量) --without-http_split_clients_module 禁用 ngx_http_split_clients_module 支持(该模块用来基于某些条件划分用户。条件如:ip 地址、报头、cookies 等等) --without-http_referer_module 禁用 disable ngx_http_referer_module 支持(该模块用来过滤请求,拒绝报头中 Referer 值不正确的请求) --without-http_rewrite_module 禁用 ngx_http_rewrite_module 支持(该模块允许使用正则表达式改变 URI,并且根据变量来转向以及选择配置。如果在 server 级别设置该选项,那么他们将在 location 之前生效。如果在 location 还有更进一步的重写规则,location部分的规则依然会被执行。如果这个 URI 重写是因为 location 部分的规则造成的,那么 location 部分会再次被执行作为新的 URI。 这个循环会执行 10 次,然后 Nginx 会返回一个 500 错误。) --without-http_proxy_module 禁用 ngx_http_proxy_module 支持(有关代理服务器) --without-http_fastcgi_module 禁用 ngx_http_fastcgi_module 支持(该模块允许Nginx 与 FastCGI 进程交互,并通过传递参数来控制 FastCGI 进程工作。 )FastCGI 一个常驻型的公共网关接口。 --without-http_uwsgi_module 禁用 ngx_http_uwsgi_module 支持(该模块用来医用uwsgi 协议,uWSGI 服务器相关) --without-http_scgi_module 禁用 ngx_http_scgi_module 支持(该模块用来启用 SCGI协议支持,SCGI 协议是 CGI 协议的替代。它是一种应用程序与 HTTP 服务接口标准。它有些像 FastCGI 但他的设计更容易实现。) --without-http_memcached_module 禁用 ngx_http_memcached_module 支持(该模块用来提供简单的缓存,以提高系统效率) -without-http_limit_zone_module 禁用 ngx_http_limit_zone_module 支持(该模块可以针对条件,进行会话的并发连接数控制) --without-http_limit_req_module 禁用 ngx_http_limit_req_module 支持(该模块允许你对于一个地址进行请求数量的限制用一个给定的 session 或一个特定的事件) --without-http_empty_gif_module 禁用 ngx_http_empty_gif_module 支持(该模块在内存中常驻了一个 1*1 的透明 GIF 图像,可以被非常快速的调用) --without-http_browser_module 禁用 ngx_http_browser_module 支持(该模块用来创建依赖于请求报头的值。如果浏览器为 modern ,则$modern_browser 等于modern_browser_value 指令分配的值;如果浏览器为 old,则$ancient_browser 等于ancient_browser_value 指令分配的值;如果浏览器为 MSIE 中的任意版本,则 $msie 等于 1) --without-http_upstream_ip_hash_module 禁用ngx_http_upstream_ip_hash_module 支持(该模块用于简单的负载均衡) --with-http_perl_module 启用 ngx_http_perl_module 支持(该模块使 nginx 可以直接使用 perl 或通过 ssi 调用 perl) --with-perl_modules_path= 设定 perl 模块路径 --with-perl= 设定 perl 库文件路径 --http-log-path= 设定 access log 路径 --http-client-body-temp-path= 设定 http 客户端请求临时文件路径 --http-proxy-temp-path= 设定 http 代理临时文件路径 --http-fastcgi-temp-path= 设定 http fastcgi 临时文件路径 --http-uwsgi-temp-path= 设定 http uwsgi 临时文件路径 --http-scgi-temp-path= 设定 http scgi 临时文件路径 --without-http 禁用 http server 功能 --without-http-cache 禁用 http cache 功能 --with-mail 启用 POP3/IMAP4/SMTP 代理模块支持 --with-mail_ssl_module 启用 ngx_mail_ssl_module 支持 --without-mail_pop3_module 禁用 pop3 协议(POP3 即邮局协议的第 3 个版本,它是规定个人计算机如何连接到互联网上的邮件服务器进行收发邮件的协议。是因特网电子邮件的第一个离线协议标准,POP3 协议允许用户从服务器上把邮件存储到本地主机上,同时根据客户端的操作删除或保存在邮件服务器上的邮件。POP3 协议是 TCP/IP 协议族中的一员,主要用于支持使用客户端远程管理在服务器上的电子邮件) --without-mail_imap_module 禁用 imap 协议(一种邮件获取协议。它的主要作用是邮件客户端可以通过这种协议从邮件服务器上获取邮件的信息,下载邮件等。IMAP 协议运行在 TCP/IP 协议之上,使用的端口是 143。它与 POP3 协议的主要区别是用户可以不用把所有的邮件全部下载,可以通过客户端直接对服务器上的邮件进行操作。) --without-mail_smtp_module 禁用 smtp 协议(SMTP 即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于TCP/IP 协议族,它帮助每台计算机在发送或中转信件时找到下一个目的地。) --with-google_perftools_module 启用 ngx_google_perftools_module 支持(调试用,剖析程序性能瓶颈) --with-cpp_test_module 启用 ngx_cpp_test_module 支持 --add-module= 启用外部模块支持 --with-cc= 指向 C 编译器路径 --with-cpp= 指向 C 预处理路径 --with-cc-opt= 设置 C 编译器参数(PCRE 库,需要指定–with-cc-opt=”-I/usr/local/include”,如果使用 select()函数则需要同时增加文件描述符数量,可以通过– with-cc- opt=”-D FD_SETSIZE=2048”指定。) --with-ld-opt= 设置连接文件参数。(PCRE 库,需要指定–with-ld-opt=”-L/usr/local/lib”。) --with-cpu-opt= 指定编译的 CPU,可用的值为: pentium, pentiumpro, pentium3,pentium4, athlon, opteron, amd64, sparc32, sparc64, ppc64 --without-pcre 禁用 pcre 库 --with-pcre 启用 pcre 库 --with-pcre= 指向 pcre 库文件目录 --with-pcre-opt= 在编译时为 pcre 库设置附加参数 --with-md5= 指向 md5 库文件目录(消息摘要算法第五版,用以提供消息的完整性保护) --with-md5-opt= 在编译时为 md5 库设置附加参数 --with-md5-asm 使用 md5 汇编源 --with-sha1= 指向 sha1 库目录(数字签名算法,主要用于数字签名) --with-sha1-opt= 在编译时为 sha1 库设置附加参数 --with-sha1-asm 使用 sha1 汇编源 --with-zlib= 指向 zlib 库目录 --with-zlib-opt= 在编译时为 zlib 设置附加参数 --with-zlib-asm= 为指定的 CPU 使用 zlib 汇编源进行优化,CPU 类型为 pentium,pentiumpro --with-libatomic 为原子内存的更新操作的实现提供一个架构 --with-libatomic= 指向 libatomic_ops 安装目录 --with-openssl= 指向 openssl 安装目录 --with-openssl-opt 在编译时为 openssl 设置附加参数 --with-debug 启用 debug 日志

文章来至:http://www.codexueyuan.com/learn/learn-detail188-lnmphuanj

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
LNMP环境指的是Linux+Nginx+MySQL+PHP的搭建。以下是LNMP环境搭建的详细步骤: 1. 安装Linux系统 首先需要选择一款适合自己的Linux系统,例如Ubuntu、CentOS等,并进行安装。 2. 安装Nginx Nginx是一款高性能的Web服务器和反向代理服务器,可以使用以下命令进行安装: ``` sudo apt-get update sudo apt-get install nginx ``` 安装完成后,启动Nginx服务: ``` sudo systemctl start nginx ``` 3. 安装MySQL MySQL是一款流行的关系型数据库,可以使用以下命令进行安装: ``` sudo apt-get install mysql-server ``` 安装完成后,启动MySQL服务: ``` sudo systemctl start mysql ``` 4. 安装PHP PHP是一种常用的服务器端脚本语言,可以使用以下命令进行安装: ``` sudo apt-get install php-fpm php-mysql ``` 安装完成后,启动PHP服务: ``` sudo systemctl start php-fpm ``` 5. 配置NginxNginx中配置PHP支持的网站,可以使用以下命令创建一个配置文件: ``` sudo nano /etc/nginx/sites-available/example.com ``` 在配置文件中添加以下内容: ``` server { listen 80; server_name example.com; root /var/www/example.com; index index.php index.html index.htm; location / { try_files $uri $uri/ /index.php?$query_string; } location ~ \.php$ { include fastcgi_params; fastcgi_pass unix:/var/run/php/php7.4-fpm.sock; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param PATH_INFO $fastcgi_path_info; } } ``` 其中,example.com是你的域名,/var/www/example.com是你的网站根目录。 创建完成后,使用以下命令激活配置文件: ``` sudo ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/ ``` 重启Nginx服务使配置生效: ``` sudo systemctl restart nginx ``` 6. 测试 在浏览器中访问你的网站,例如http://example.com,如果一切正常,你应该能够看到你的网站。 至此,LNMP环境搭建完成。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值