LNMP 环境搭建
更新时间:2024-02-28 23:46:01 阅读量: 综合文库 文档下载
- lnmp推荐度:
- 相关推荐
Linux Red Hat 6.4下 Nginx + Mysql + PHP
服务器环境搭建
系统平台:RHEL 6.4 Nginx版本:nginx-1.1.8 Mysql版本:5.1.59 PHP版本:php-5.2.17
安装准备
在安装Linux操作系统时添加如下几个包,不然无法使用源码安装
关于依赖包的问题:
用 rpm -qa | grep 依赖包名
查看是否安装了改该包,然后安装其相应的devel文件即可 比如:
#rpm -qa | grep libxxx libxxx-1.0.0.el6.x86_64 其devel包的名字为
libxxx-devel-1.0.0.el6.x86_64
1.安装libiconv
#tar zxvf libiconv-1.13.tar.gz #cd libiconv-1.13/
#./configure --prefix=/usr/local #make
#make install cd ../
2.安装libmcrypt 实现加密功能的库
# tar zxvf libmcrypt-2.5.8.tar.gz # cd libmcrypt-2.5.8/ # ./configure # make
# make install # /sbin/ldconfig
# 注:这里不要退出去。
# cd libltdl/
# ./configure --enable-ltdl-install # make
# make install
3.安装mhash(哈稀函数库) # tar zxvf mhash-0.9.9.9.tar.gz # cd mhash-0.9.9.9/ # ./configure # make
# make install # cd ../
ln -s /usr/local/lib/libmcrypt.la /usr/lib/libmcrypt.la ln -s /usr/local/lib/libmcrypt.so /usr/lib/libmcrypt.so ln -s /usr/local/lib/libmcrypt.so.4 /usr/lib/libmcrypt.so.4 ln -s /usr/local/lib/libmcrypt.so.4.4.8 /usr/lib/libmcrypt.so.4.4.8 ln -s /usr/local/lib/libmhash.a /usr/lib/libmhash.a ln -s /usr/local/lib/libmhash.la /usr/lib/libmhash.la ln -s /usr/local/lib/libmhash.so /usr/lib/libmhash.so ln -s /usr/local/lib/libmhash.so.2 /usr/lib/libmhash.so.2 ln -s /usr/local/lib/libmhash.so.2.0.1 /usr/lib/libmhash.so.2.0.1 4. 安装mcrypt
# tar zxvf mcrypt-2.6.8.tar.gz # cd mcrypt-2.6.8/ # /sbin/ldconfig #./configure # make # make install # cd ../
如果出现libmcrypt not found的错误 执行下面的语句:
#exprot LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH
5. 安装libxml2-devel
# rpm -ivh libxml2-devel-2.7.6-8.el6_3.4.x86_64.rpm 6.安装libpng-devel
# rpm -ivh libpng-devel-1.2.49-1.el6_2.x86_64.rpm 7.安装freetype、freetype-devel
# rpm -ivh freetype-devel-2.3.11-6.el6_2.9.x86_64.rpm 8.安装 openssl-devel
# rpm -ivh openssl-devel-1.0.0-27.el6.x86_64.rpm # openssl-devel依赖于krb5-devel #
rpm -ivh krb5-devel-1.10.3-10.el6.x86_64.rpm
# krb5-devel 依赖于 # # # #
rpm -ivh keyutils-libs-devel-1.4-4.el6.x86_64.rpm rpm -ivh libcom_err-devel-1.41.12-14.el6.x86_64.rpm rpm -ivh libselinux-devel-2.0.94-5.3.el6.x86_64.rpm
libselinux-devel依赖于
rpm -ivh libsepol-devel-2.0.41-4.el6.x86_64.rpm
9.安装nucurese
# tar -zxvf ncurses-5.6.tar.gz # cd ncurses-5.6 #./configure
--with-shared
--without-debug
--without-ada
--enable-overwrite # make
# make install
Mysql安装
先用rpm -qa | grep mysql 查看是否已经安装mysql 如果显示:
MySQL-server-* MySQL-client-*
用 rpm -e mysql* -nodeps 将其卸载 删除mysql服务
# chkconfig --list | grep -i mysql #chkconfig --del mysql
Whereis mysql 删除残留文件夹
建立mysql组,建立mysql用户并且加入到mysql组中 # groupadd mysql
# useradd mysql -g mysql # tar zxvf mysql-5.1.59.tar.gz # cd mysql-5.1.59
# ./configure --prefix=/usr/local/mysql --without-debug
--with-extra-charsets=gbk --with-extra-charsets=all --enable-assembler --with-pthread
--enable-thread-safe-client
--with-mysqld-ldflags=-all-static /*不带共享库的形式编译mysqld*/ --with-client-ldflags=-all-static --with-big-tables
--with-readline /*要采用rpm方式安装ncurses或tar包安装*/
--with-ssl /*要采用rpm方式安装openssl*/ --with-embedded-server --enable-local-infile --with-plugins=innobase # make # make install
# /usr/local/mysql/bin/mysql_install_db --user=mysql #以Mysql身份初始化数据库
# cp ./support-files/mysql.server /etc/init.d/mysql #复制Mysql启动服务至系统
# cp ./support-files/my-medium.cnf /etc/my.cnf # chmod 755 /etc/init.d/mysql
# cd /usr/local/mysql/ #切换到cd /usr/local/mysql/目录下 # chown -R mysql . #改变当前目录下的所有者为mysql用户 # chown -R mysql /var/lib/mysql/ #修改数据库目录的权限
# chgrp -R mysql . #改变当前目录下的mysql用户的文件为mysql组
# /usr/local/mysql/bin/mysqld_safe --user=mysql& # service mysql start #启动mysql服务
如果出现找不到mysql.sock文件,修改 /etc目录下的my.cof文件 把 socket=/var/lib/mysql.sock改成socket=/tmp/mysql.sock即可
# /usr/local/mysql/bin/mysqladmin -u root password 'admin' #设置管理员密码
# /usr/local/mysql/bin/mysql -u root -p #测试密码输入
# mysql> \\q /*退出mysql*/
# chkconfig --add mysql #添加mysqld服务到系统 # chkconfig mysql on #打开myslqd服务 # service mysql restart #重启Mysql
PHP 安装
依赖包
# rpm -ivh libidn-devel-1.18-2.el6.x86_64.rpm # rpm -ivh libcurl-devel-7.19.7-35.el6.x86_64.rpm # rpm -ivh cyrus-sasl-devel-2.1.23-13.el6_3.1.x86_64.rpm # rpm -ivh openldap-devel-2.4.23-31.el6.x86_64.rpm # rpm -ivh libjpeg-turbo-devel-1.2.1-1.el6.x86_64.rpm ./configure 中如果报libjpeg.(a|so)not found错误 检查libjpeg是否安装,如果安装了
# cp -frp /usr/lib64/libjpeg.* /usr/lib/ libpng libldap同理
# cp -frp /usr/lib64/libpng* /usr/lib/ # cp -frp /usr/lib64/libldap* /usr/lib/
# tar -zxvf php-5.2.17.tar.gz
# gzip -cd php-5.2.17-fpm-0.5.14.diff.gz | patch -d php-5.2.17 -p1 # cd php-5.2.17
./configure --prefix=/usr/local/php \\ --with-config-file-path=/usr/local/php/etc \\ --with-mysql=/usr/local/mysql/ \\
--with-mysqli=/usr/local/mysql/bin/mysql_config --with-iconv-dir=/usr/local/ \\ --with-freetype-dir
--with-jpeg-dir
--with-png-dir
--with-zlib
--with-libxml-dir=/usr/ \\
--enable-xml --disable-rpath --enable-discard-path --enable-bcmath \\ --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers \\ --enable-mbregex --with-mcrypt
--with-gd
--enable-fastcgi --enable-gd-native-ttf
--enable-fpm --with-openssl
--enable-force-cgi-redirect --enable-mbstring \\ --with-mhash --enable-pcntl \\
--enable-sockets --with-ldap --with-ldap-sasl --with-xmlrpc --enable-zip --enable-soap
--enable-safe-mode \\\\此选项可选,如果使用可以增加安全性,但是一些功能会被制约 # make ZEND_EXTRA_LIBS='-liconv' #直接make会报错 # make install Php-fpm配置
php-fpm是为PHP打的一个FastCGI管理补丁,可以平滑变更php.ini配置而无需重启php-cgi: 创建用户与用户组
/usr/sbin/groupadd www /usr/sbin/useradd -g www www
将 /usr/local/php/etc/php-fpm.conf 重命名 #备份原文件 创建名为php-fpm.conf的文件输入以下内容:
/usr/local/php/sbin/php-fpm start 注:/usr/local/php/sbin/php-fpm还有其他参数,包括: start|stop|quit|restart|reload|logrotate,修改php.ini后不重启php-cgi,重新加载配置文件使用reload,就保持了在php的fastcgi进程持续运行的状态下,又重新加载了php.ini。 Nginx 安装 1、安装rewrite模块支持包pcre库: pcre是perl所用到的正则表达式,目的是让所装的软件支持正则表达式。默认情况下,Nginx只处理静态的网页请求,也就是html.如果是来自动态的网页请求,比如*.php,那么Nginx就要根据正则表达式查询路径,然后把*.PHP交给PHP去处理。 # tar zxvf pcre-7.9.tar.gz # cd pcre-7.9/ # ./configure # make && make install cd ../ 2.安装Nginx # tar zxvf nginx-1.1.8.tar.gz # cd nginx-1.1.8/ #./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module # make # make install 3.Nginx 安装后只有一个程序文件,本身并不提供各种管理程序,它是使用参数和系统信号机制对 Nginx 进程本身进行控制的。 Nginx 的参数包括有如下几个: -c -V:显示 nginx 的版本号以及编译环境信息以及编译时的参数。 例如我们要测试某个配置文件是否书写正确,我们可以使用以下命令 sbin/nginx -t -c conf/nginx.con nginx配置 1.在/usr/local/nginx/conf/目录中创建nginx.conf文件: rm -f /usr/local/nginx/conf/nginx.conf vi /usr/local/nginx/conf/nginx.conf ======================================= nginx.conf才是nginx web服务器的配置文件 ======================================= user www www; #/*启动nginx服务的用户与组*/ worker_processes 1; #/*启动nginx服务的工作进程*/ error_log logs/nginx_error.log crit; #/*错误日志,以及等级*/ pid /usr/local/nginx/nginx.pid; #/*nginx服务进程PID*/ worker_rlimit_nofile 51200; events { use epoll; #/*工作模式*/ worker_connections 51200; #/*每进程允许最大的同时连接数*/ } http { include mime.types; default_type application/octet-stream; #charset gb2312; server_names_hash_bucket_size 128; client_header_buffer_size 32k; large_client_header_buffers 4 32k; sendfile on; tcp_nopush on; keepalive_timeout 60; tcp_nodelay on; fastcgi_connect_timeout 300; fastcgi_send_timeout 300; fastcgi_read_timeout 300; fastcgi_buffer_size 64k; fastcgi_buffers 4 64k; fastcgi_busy_buffers_size 128k; fastcgi_temp_file_write_size 128k; gzip on; gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.0; gzip_comp_level 2; gzip_types text/plain application/x-javascript text/css application/xml; gzip_vary on; #limit_zone crawler $binary_remote_addr 10m; server { listen 80; #/*监听端口*/ server_name localhost; #/*服务器名称*/ index index.html index.htm index.php; #/*缺省主页名称*/ root /usr/local/nginx/html; #/*网站根目录,也可以采用下面内容*/ #也可以采用相对路径,下面注释部分*/ #location / { # root html; # index index.html index.htm; # } #limit_conn crawler 20; #通过FastCGI方式支持PHP,php页面由fastcgi代理处理,这也是反向代理的一个应用,这里可以是jsp/asp等脚本。 #Nginx是通过本机的9000端口将PHP请求转发给PHP的,PHP自己是从本机的9000端口侦听数据,Nginx与PHP通过本机的9000端口完成了数据请求。 location ~ .*\\.(php|php5)?$ { #fastcgi_pass unix:/tmp/php-cgi.sock; fastcgi_pass 127.0.0.1:9000; #/*fastcgi监听端口*/ fastcgi_index index.php; include fcgi.conf; #/*fastcgi配置文件,修改为以下内容*/ } #对于某一类型的文件,设置过期时间,静态的页面通常设置长一点。 #静态文件,nginx自己处理 location ~ .*\\.(gif|jpg|jpeg|png|bmp|swf|js|css)$ { expires 30d; } #日志的格式 log_format access '$remote_addr - $remote_user [$time_local] \ '$status $body_bytes_sent \ '\ access_log logs/access.log access; } } 说明:以上配置文件只是基本配置文件,要实现其它功能的话,需要在此基础上进行修改。 2.在/usr/local/nginx/conf/目录中创建fcgi.conf文件: 说明:可以直接粘贴以下内容。 vi /usr/local/nginx/conf/fcgi.conf fastcgi_param GATEWAY_INTERFACE CGI/1.1; fastcgi_param SERVER_SOFTWARE nginx; fastcgi_param QUERY_STRING $query_string; fastcgi_param REQUEST_METHOD $request_method; fastcgi_param CONTENT_TYPE $content_type; fastcgi_param CONTENT_LENGTH $content_length; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_param REQUEST_URI $request_uri; fastcgi_param DOCUMENT_URI $document_uri; fastcgi_param DOCUMENT_ROOT $document_root; fastcgi_param SERVER_PROTOCOL $server_protocol; fastcgi_param REMOTE_ADDR $remote_addr; fastcgi_param REMOTE_PORT $remote_port; fastcgi_param SERVER_ADDR $server_addr; fastcgi_param SERVER_PORT $server_port; fastcgi_param SERVER_NAME $server_name; # PHP only, required if PHP was built with --enable-force-cgi-redirect fastcgi_param REDIRECT_STATUS 200; nginx启动与管理 1.启动nginx /usr/local/nginx/sbin/nginx 2.测试nginx配置文件 修改/usr/local/nginx/conf/nginx.conf配置文件后,请执行以下命令检查配置文件是否正确: # /usr/local/nginx/sbin/nginx -t 如果屏幕显示以下两行信息,说明配置文件正确: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok the configuration file /usr/local/nginx/conf/nginx.conf was tested successfully 3.查看Nginx主进程号 ps -ef | grep \屏幕显示的即为Nginx主进程号,例如: 6302 这时,执行以下命令即可使修改过的Nginx配置文件生效: # kill -HUP 6302 或者无需这么麻烦,找到Nginx的Pid文件: # kill -HUP `cat /usr/local/nginx/logs/nginx.pid` 重启nginx # /usr/local/nginx/sbin/nginx -s reload 4.配置开机自动启动Nginx + PHP vi /etc/rc.local 加入以下内容: ulimit -SHn 51200 /usr/local/php/sbin/php-fpm start /usr/local/nginx/sbin/nginx 5.测试nginx vi /usr/local/nginx/html/phpinfo.php phpinfo(); ?>
正在阅读:
LNMP 环境搭建02-28
2022届高考地理复习自然地理第一章行星地球题组层级快练2等高线04-07
HS600(新)说明书05-22
人教版四年级口算、两位数乘法练习 -10-12
最新-县2019年教育工作情况报告 精品12-18
影响煤层气钻井完井工艺技术的几个问题05-11
保护庄稼的好朋友看图写话06-19
论艺术治疗与中国传统艺术精神的契合04-24
2017年吉林省实验员试题及答案八大员06-10
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- 搭建
- 环境
- LNMP