我主要是用来安装php,以及nginx和php的交互。

一 安装插件

可以选择YUM安装或者源码编译安装gccgcc-c++zlib

pcre

pcre-devel

libevent

libevent-devel

libxml2

libxml2-devel

libmcrypt

libmcrypt-devel

curl-devel

libpng-devel

libtool-ltdl-devel

gd-devel

openssl

openssl-devel

ncurses-devel

cmake

mysql-devel

二 安装mysql

tar -zxvf mysql-5.5.25.tar.gz

将mysql包解压 然后放入你想要mysql的安装位置 如本例中的/usr/local/webserver/mysql cmake命令需要这个路径cmake \-DCMAKE_INSTALL_PREFIX=/usr/local/webserver/mysql \-DMYSQL_DATADIR=/user/local/webserver/mysql/data \-DSYSCONFDIR=/etc \-DEXTRA_CHARSETS=all \-DDEFAULT_CHARSET=utf8 \-DDEFAULT_COLLATION=utf8_general_ci \-DWITH_INNOBASE_STORAGE_ENGINE=1\-DWITH_ARCHIVE_STORAGE_ENGINE=1\-DWITH_BLACKHOLE_STORAGE_ENGINE=1\-DWITH_FEDERATED_STORAGE_ENGINE=1\-DWITH_PARTITION_STORAGE_ENGINE=1\-DWITH_PERFSCHEMA_STORAGE_ENGINE=1\-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \-DMYSQL_TCP_PORT=3306\-DWITH_DEBUG=0\-DENABLED_LOCAL_INFILE=1回车执行,执行完成后继续执行make && makeinstall#设置Mysql

#在support-files目录中有五个配置信息文件(这里很重要,一定要根据自己的内存复制对应的cnf文件,否则mysql始终起不来):

#my-small.cnf (内存<=64M)

#my-medium.cnf (内存 128M)

#my-large.cnf (内存 512M)

#my-huge.cnf (内存 1G-2G)

#my-innodb-heavy-4G.cnf (内存 4GB)

cd/usr/local/webserver/mysqlcp ./support-files/my-huge.cnf /etc/my.cnf

vi/etc/my.cnf

#在 [mysqld] 段增加

datadir= /usr/local/webserver/mysql/datawait-timeout = 30max_connections= 512default-storage-engine =MyISAM

#在 [mysqld] 段修改

max_allowed_packet=16M//添加mysql运行的用户和用户组groupadd mysql

useradd-g mysql mysql -s /bin/false -d /home/mysql //没有shell,不可本机登陆(安全起见)cd/usr/local/webserver/mysqlchown -R root .chown -R mysql datachgrp -R mysql .//生成新的mysql授权表//进入mysql安装目录下的脚本目录 cd /usr/local/webserver/mysql/scripts//利用mysql_install_db脚本生成新的mysql授权表 ./mysql_install_db --basedir=/usr/local/webserver/mysql --datadir=/usr/local/webserver/mysql/data --user=mysql//mysql server在系统中的服务项设置//复制服务文件并修改 cd /usr/local/webserver/mysql/support-filescpmysql.server mysqld//修改mysqld basedir=/usr/local/webserver/mysql

datadir=/usr/local/webserver/mysql/datamv mysqld /etc/init.d/mysqldchmod755 /etc/init.d/mysqld

进行上述操作后 我们可以用 service mysqld start 来启动mysql服务了//设置软连接使mysql, mysqldump, mysqladmin这三个bin命令能在shell中直接运行sudoln -s /usr/local/webserver/mysql/bin/mysql /usr/binsudoln -s /usr/local/webserver/mysql/bin/mysqldump /usr/binsudoln -s /usr/local/webserver/mysql/bin/mysqladmin /usr/binrm -rf /etc/mysql/my.cnf 因为已经把此文件复制到/etc/my.cnf 如果不删除的话,mysql启动不起来。/etc/init.d/mysqld start//设置root密码 mysqladmin -u root password "admin"//mysql数据库中文乱码解决 vi /etc/my.cnf//然后在[mysqld]配置选项下添加 character-set-server=utf8//然后进入mysql cd /usr/local/webserver/mysql/bin

mysql-u root -p

提示输入密码

mysql> show variables like '%character%';

三 安装Nginx

#tar zxvf nginx-0.8.24.tar.gz

#cd nginx-0.8.24#./configure --prefix=/usr/local/nginx //此处在本环节只需指定一个路径 #make && makeinstall#/usr/local/nginx/sbin/nginx //启Nginx编写服务脚本(服务脚本请勿复制 请在linux下写入 不然回车换行符会引起异常)

vi/etc/init.d/nginx

把下列内容写入文件并保存 #!/bin/bash

# nginx Startup script for the Nginx HTTP Server

# this script create it by gcec at 2009.10.22.

# it is v.0.0.1 version.

# if you find any errors on this scripts,please contact gcec cyz.

# and send mail to support at gcec dot cc.

#

# chkconfig: - 85 15

# description: Nginx is a high-performance web and proxy server.

# It has a lot of features, but it's not for everyone.

# processname: nginx

# pidfile: /var/run/nginx.pid

# config: /usr/local/nginx/conf/nginx.conf

nginxd=/usr/local/nginx/sbin/nginx #这里设置为你安装nginx的执行文件位置

nginx_config=/usr/local/nginx/conf/nginx.conf #这里设置为你nginx的配置文件位置

nginx_pid=/var/run/nginx.pid

RETVAL=0

prog="nginx"

# Source function library.

. /etc/rc.d/init.d/functions

# Source networking configuration.

. /etc/sysconfig/network

# Check that networking is up.

[ ${NETWORKING} = "no" ] && exit 0

[ -x $nginxd ] || exit 0

# Start nginx daemons functions.

start() {

if [ -e $nginx_pid ];then

echo "nginx already running...."

exit 1

fi

echo -n $"Starting $prog: "

daemon $nginxd -c ${nginx_config}

RETVAL=$?

echo

[ $RETVAL = 0 ] && touch /var/lock/subsys/nginx

return $RETVAL

}

# Stop nginx daemons functions.

stop() {

echo -n $"Stopping $prog: "

killproc $nginxd

RETVAL=$?

echo

[ $RETVAL = 0 ] && rm -f /var/lock/subsys/nginx /var/run/nginx.pid

}

# reload nginx service functions.

reload() {

echo -n $"Reloading $prog: "

#kill -HUP `cat ${nginx_pid}`

killproc $nginxd -HUP

RETVAL=$?

echo

}

# See how we were called.

case "$1" in

start)

start

;;

stop)

stop

;;

reload)

reload

;;

restart)

stop

start

;;

status)

status $prog

RETVAL=$?

;;

*)

echo $"Usage: $prog {start|stop|restart|reload|status|help}"

exit 1

esacexit $RETVAL 保存之后 赋予文件权限

chmod 755 /etc/init.d/nginx

我们就可以通过service nginx start 来启动服务了

四 安装php

create user and group forfpm(fastcgi process manager)

groupadd fpm

useradd--shell /sbin/nologin -g fpm fpm

download, configure andinstall php5.3.3wget http://www.php.net/distributions/php-5.3.3.tar.gztar zxvf php-5.3.3.tar.gz

cd php-5.3.3

[直接复制]

./configure --prefix=/usr/local/php --enable-fpm --with-fpm-user=fpm --with-fpm-group=fpm --with-config-file-path=/usr/local/php/lib --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --without-pdo-sqlite --without-sqlite3 --without-sqlite --with-curl --enable-mbstring --with-mhash --with-mcrypt --with-openssl --with-gd --enable-sockets --with-gettext --with-zlib --enable-zip --enable-soap --with-xmlrpc --with-freetype-dir=/usr/local/freetype --enable-gd-native-ttf

--disable-fileinfo

中途错误需要yum install几个依赖包[手敲版]

./configure --prefix=/usr/local/php \--enable-fpm \--with-fpm-user=fpm \--with-fpm-group=fpm \ --with-config-file-path=/usr/local/php/lib #这里是配置放php.ini的存放位置--with-mysql=mysqlnd \--with-mysqli=mysqlnd \--with-pdo-mysql=mysqlnd \--without-pdo-sqlite \--without-sqlite3 \--without-sqlite \--with-mysql-sock=/tmp/mysql.sock \--with-curl \--enable-mbstring \--with-mhash \--with-mcrypt \--with-openssl \--with-gd \--enable-sockets \--with-gettext \--with-zlib \--enable-zip\--enable-soap \--with-xmlrpc \

--with-freetype-dir=/usr/local/freetype \

--enable-gd-native-ttf \ --with-jpeg-dir=/usr/lib64 #64位系统lib64 32位系统lib32make && makeinstall

make出现错误virtual memory exhausted: Cannot allocate memory,在configure上加上–disable-fileinfo

如果出现mysql_config not found的错误

解决办法: vi /etc/profile 在最后加入一行 export PATH="$PATH:/usr/local/mysql/bin" 这个是你的mysql安装到的目录

五 配置php

cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf

复制源码包里的php.ini-development到/usr/local/php/lib vi php-fpm.conf

找到"listen=" 修改为 listen = /dev/shm/php-fpm.sock (要求php版本5.3以上 该方式为使用sock文件监听)

cp /backup/php-5.3.3/php.ini-development /usr/local/php/lib/php.ini

启动php

/usr/local/php/sbin/php-fpm 如果设置路径正确,php.ini文件也存在,还无法加载php.ini的话 修改启动命令 /usr/local/php/sbin/php-fpm -c /etc/php.ini编写服务脚本(服务脚本请勿复制 请在linux下写入 不然回车换行符会引起异常)

touch /etc/init.d/phpfpm

vim /etc/init.d/phpfpm

内容如下:

#!/bin/bash

start() {

/usr/local/php/sbin/php-fpm

/bin/echo 'starting php listener ---[ok]'

}

stop() {

/usr/bin/pkill php-fpm

/bin/echo 'stopping php listener ---[ok]'

}

case "$1" in

start)

start

;;

stop)

stop

;;

restart)

stop

start

;;

*)

echo 'usage:start/stop/restart'

exit 0

;;

esac

保存退出

然后 就能通过 service phpfpm start/stop/restart 来启动监听

六 配置Nginx

cat /usr/local/php/etc/php-fpm.conf

查看端口 为 127.0.0.1:9000

修改nginx配置文件 /usr/local/nginx/conf/nginx.conf# location / { //一定要注掉这部分,否则会不解析PHP文件,而会下载 了

# root html;

# index index.html index.htm;

#}

location~ \.php {

root    www; #这是你网站的根目录

fastcgi_pass  127.0.0.1:9000; #这里指定了fastcgi进程侦听的端口,nginx就是通过这里与php交互的

#fastcgi_pass unix:/dev/shm/php-fpm.sock;

fastcgi_index  index.php;   fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name;

#因为SCRIPT_FILENAME在配置中是写死的并没有随着$doucument_root变化而变化,我们可以修改SCRIPT_FILENAME配置如下 #fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;include    fastcgi_params;

} 重启nginx服务

/usr/local/nginx/sbin/nginx -s reload

在/usr/local/nginx下创建www目录

mkdir www

新建一个index.php文件

cd www

vim index.php

写入

访问服务器 如果起作用就说明配置成功

七 设置php nginx mysql 自启动

我想在centos里不启用图形界面

那么选择系统运行级别为2或者3的 推荐3在配置之前 我们先检查下 /etc/init.d中有没有我们mysql,php,nginx的服务脚本 如果没有的话 先配置再做下列操作

如以上 mysqld , nginx, phpfpm 这3个脚本都编写好 并且放入/etc/init.d下的话 我们来配置一下自启动

我想通过一个服务来启动这3个服务那么再写一个脚本就可以了

注意:system类型的服务都可以用service来启动,用chkconfig来add 和del

但是有些自己配置的服务在用chkconfig来配置到时候会提示: “service XX does not support chkconfig”

这一般都是script不符合格式造成的,解决如下,

在script开始加入两行内容即可:

# chkconfig: - 85 15

# description: this is a World Wide Web server.

mv /etc/init.d/mysqld /etc/init.d/webapp-mysqldmv /etc/init.d/nginx /etc/init.d/webapp-nginxmv /etc/init.d/phpfpm /etc/init.d/webapp-phpfpmtouch /etc/init.d/webappvim /etc/init.d/webapp写入以下脚本

#!/bin/bash

# chkconfig: - 85 15

# description: this is a World Wide Web server.

ACTION=$1

if [ "$ACTION" = "" ] || [ "$ACTION" = "start" ];then

#start php listeners

/sbin/service webapp-phpfpm start

#start nginx service

/sbin/service webapp-nginx start

#start mysql service

/sbin/service webapp-mysqld start

echo "web applications[mysql,nginx,php] is running now !"

elif [ "$ACTION" = "stop" ];then

/sbin/service webapp-phpfpm stop

/sbin/service webapp-nginx stop

/sbin/service webapp-mysqld stop

echo 'web application stopped'

else

echo "use start or stop or none after your service command"

fi

添加系统服务开机启动

chkconfig --add webapp(注意在/etc/init.d下的服务脚本必须加入#chkconfig 和 #description的内容才能够在这里支持chkconfig命令,以上已经提到过)

chkconfig --level 3 webapp on

这样我们的lamp的架构就配置成功了

说明:

语法为:

chkconfig --list [name] 用来列表服务

chkconfig --add name 用来添加服务

chkconfig --del name 用来删除服务

chkconfig [--level levels] name 改变启动信息以及检查特定服务的启动状态。

on 和 off 分别指服务在改变运行级时的启动和停止。reset 指初始化服务信息。

对于 on 和 off 开关,系统默认只对运行级 3,4, 5有效,但是 reset 可以对所有运行级有效。

以上就介绍了linux下 php+nginx+mysql安装配置,包括了mysql安装方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

linux 安装nginx php mysql 配置文件在哪_linux下 php+nginx+mysql安装配置相关推荐

  1. mysql数据库ftp备份_Linux下自动备份MySQL数据库并上传到远程FTP服务器且删除指定日期前的备份Shell脚本...

    说明: 1.备份MySQL数据库存放目录/var/lib/mysql下面的vos3000db数据库到/home/mysql_data里面,并且保存为vos3000db_bak_2012_06_30.t ...

  2. php mysql编译安装目录_Linux下Apache PHP MySQL默认安装路径

    Linux下Apache PHP MySQL默认安装路径 Apache 如果采用RPM包安装,安装路径应在 /etc/httpd目录下 Apache配置文件: /etc/httpd/conf/http ...

  3. 查看linux mysql 账户权限设置_Linux下mysql新建账号及权限设置各种方式总结

    来自:http://justcoding.iteye.com/blog/1941116 1.权限赋予 说明:mysql部署在服务器A上,内网上主机B通过客户端工具连接服务器A以进行数据库操作,需要服务 ...

  4. linux mysql 5.7 配置_linux下mysql5.7的安装配置

    mysql官方下载地址: https://dev.mysql.com/downloads/mysql/ 安装步骤: # https://cdn.mysql.com//Downloads/MySQL-5 ...

  5. linux mysql配置文件中修改ip_linux下mysql配置文件my.cnf详解

    basedir = path 使用给定目录作为根目录(安装目录). character-sets-dir = path 给出存放着字符集的目录. datadir = path 从给定目录读取数据库文件 ...

  6. linux 64 mysql下载官网_Linux下安装MySQL5.7

    Oracle提供很多MySQL的发行版本,其中就包括压缩在tar文件(.tar.gz)内的通用二进制版本,下面介绍如何在Linux上安装这种版本的MySQL5.7,首先从官网下载MySQL,这里使用6 ...

  7. linux 安装qt mysql库_Linux下QT平台Mysql数据库开发环境配置

    This doucment is about how to add mysql driver into QT and about database connections     由于之前安装RedH ...

  8. linux安装mysql遇到的问题_Linux下安装MySQL5.7及遇到的问题解决方法

    一.下载地址 本文安装的版本: 或者使用wget下载: [root@localhost opt]# wget https://dev.mysql.com/get/Downloads/MySQL-5.7 ...

  9. linux mysql web界面吗_Linux下安装MySQL Web 管理工具phpMyAdmin

    一.安装Apache 二.安装依赖包 sudo yum install gd sudo yum install libpng-devel sudo yum install libjpeg-devel ...

最新文章

  1. PatchMatchStereo中的深度/视差传播策略
  2. 软件:向工业互联网产业成功转型的关键
  3. [Linux] set dev label(设置分区卷标)
  4. Linux C编程--进程间通信(IPC)6--综合应用实例--信号量和共享内存的使用
  5. 背水一战 Windows 10 (61) - 控件(媒体类): InkCanvas 涂鸦编辑
  6. Zabbix3.2安装
  7. 用GitHub Issue取代多说,是不是很厉害?
  8. 浅谈LINQ to SQL集成数据库语言优劣
  9. 蓝桥杯 ALGO-42 算法训练 送分啦
  10. ubuntu安装之后需要做什么
  11. Java常用类(三):FileUtils类
  12. MySQL数据库面试题(2022最新版)
  13. Windows10三月更新后,电脑打印文件时蓝屏解决方案
  14. Xshell传输文件
  15. 利用python做中文词频分析
  16. MQTT网关是什么?
  17. [ble_mesh]3.9 Mesh beacon
  18. 个人晋升演讲ppt_如何写好公司级别晋升 PPT?
  19. 【专家级前端JavaScript面试题】快来尝试一下
  20. 计算机固态地址是什么,SSD固态硬盘安装到笔记本电脑什么位置比较合适

热门文章

  1. PopupWindow 使用详解(二) Popwindow 制作常见花哨效果
  2. 怎样下载C/C++的免费、开源且跨平台IDE——Code::Blocks
  3. 安装MariaDB数据库(未完成)
  4. iOS 修改项目名称
  5. Docker image Introduce
  6. Java探索之旅(11)——抽象类与接口
  7. 五个在线图形工具创建简单的设计元素
  8. 列出C#进程以及详细信息
  9. PartitionMotionSearch()函数
  10. matlab常用函数——数据类型函数