nginx + mysql + php相关源码包及安装

时间:2022-08-22 18:00:07

nginx + mysql + php安装

引言

完整的搭建一个nginx+php-fpm+mysql的服务器,一直是我向做的,不过一致没有完成过,这次工作需要,终于安装成功了

我列出了我遇到的一些问题,当然可能读者自己尝试的时候还会有些问题,可以贴出来一起讨论讨论。

这里的创建用户组什么的也省略掉了,想看的可以看参考链接里面的内容。

github里面有详细的安装步骤,和用到的大部分软件源码包,下面是github地址

https://github.com/aizuyan/install-php-fpm_nginx_mysql

nginx安装

nginx源码包:nginx,密码:bi79

pcre源码包:pcre,密码:uvqd

zlib源码包:zlib,密码:i6pf

配置里面的--prefix制定了nginx的安装目录,--conf-path制定了nginx配置文件的目录,这里的--with-pcre=后面的目录是pcre的源码包目录,--with-zlib=后面的是zlib源码包的路径。

./configure --prefix=/usr/local --sbin-path=/usr/local/nginx/nginx --conf-path=/usr/local/nginx/nginx.conf --pid-path=/usr/local/nginx/nginx.pid --with-http_ssl_module --with-pcre=../pcre-8.36 --with-zlib=../zlib-1.2.8

mysql安装

mysql源码包:mysql,密码:7qyu

mysql安装使用的是cmake,没有的自安装,apt-get install cmake

安装ncurses-devel,在ubuntu下面是apt-get install apt-get install libncurses5-dev

下民命令中的-DCMAKE_INSTALL_PREFIX=后面是mysql的安装目录,-DMYSQL_UNIX_ADDR=后面是监听套接字的路径,默认为/tmp/mysql.sock,-DDEFAULT_CHARSET设置服务器字符集,默认是latin1,-DMYSQL_DATADIR设置mysql数据的存储目录。

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DMYSQL_DATADIR=/data/mysqldb -DMYSQL_TCP_PORT=3306 -DENABLE_DOWNLOADS=1

mysql安装完之后启动服务器可能还会有很多问题,下面列几个可能的问题:

  1. 配置文件的问题,mysql加载配置文件my.cnf的时候有个默认顺序:

    a. /etc/my.cnf

    b. /etc/mysql/my.cnf

    c. /usr/local/mysql/my.cnf

    d. ~/my.cnf

    因此要是出现一些很奇怪的不好解决的问题一定要先看看是不是加载了你想要mysql加载的配置文件。

    下面是我安装的mysql的配置文件参考:

    [mysqld]

    port=3306

    socket=/usr/local/mysql/mysql.sock

    datadir=/data/mysqldb

    character_set_server=utf8

    sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

    [mysql]

    socket=/usr/local/mysql/mysql.sock

    [mysqladmin]

    socket=/usr/local/mysql/mysql.sock

php安装

php源码包:php,密码:uip8

freetype源码包:freetype,密码:m5pc

freetype生成验证码的时候会用到(具体的就是imagettftext这个函数)

可能需要安装的:apt-get install curl libcurl3 libcurl3-dev,apt-get install libpng3 libpng3-dev,apt-get install libmcrypt4 libmcrypt-dev

下面的安装配置里面。/usr/local/mysql为你安装mysql的目录。

./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --enable-fpm --enable-pcntl --enable-mysqlnd --enable-opcache --enable-sockets --enable-sysvmsg --enable-sysvsem  --enable-sysvshm --enable-shmop --enable-zip --enable-ftp --enable-soap --enable-xml --enable-mbstring --with-mysql=/usr/local/mysql -with-pdo-mysql=/usr/local/mysql --with-pcre-regex --with-iconv --with-zlib --with-mcrypt --with-gd --with-openssl --with-mhash --with-xmlrpc --with-curl --with-imap-ssl --enable-pdo --with-freetype-dir=/usr/local/freetype
安装phpredis扩展

phpredis源码包:phpredis,密码:dvxe

步骤:

a. $tar -zxvf phpredis-2.2.4.tar.gz

b. $cd phpredis-2.2.4

c. $/usr/local/php/bin/phpize

d. $ ./configure --with-php-config=/usr/local/php/bin/php-config

e. $make && make install

f. $vim /usr/local/php/etc/php.ini,添加下面的内容extension="redis.so"

g. 重启php-fpm或者apache

收尾

  1. sbin/php-fpm -c etc/php.ini -y etc/php-fpm.conf -t这里的php-fpm的-c参数表示要加在配置文件的位置,-y表示要加在php-fpm专用配置文件的位置,也可以使用缺省参数,-t表示测试配置文件是否ok。
  2. mysql安转完了之后要先安装初始数据库scripts/mysql_install_db --user=mysql --datadir=/data/mysqldb--user=后面的是指定运行mysqld的用户,--datadir=后面是mysql数据的目录。
  3. support-files/mysql.server就是mysqld,mysql客户端在bin/mysql这个位置。

参考链接

http://www.cnblogs.com/suihui/archive/2013/04/13/3018557.html

http://blog.csdn.net/wendi_0506/article/details/39478369

www.cnblogs.com/argb/p/3604340.html