源码安装mysql
新安装的linux 6.3
/etc/init.d/postfix stop 停止postfix
卸载mysql rpm -e mysql-libs --nodeps #需要将postfix 服务关闭,要不然就启动不了。
rpm -qa | grep php
rpm -qa | grep apache
下载最新版本的mysql 5.5
tar zxf cmake-2.8.4.tar.gz
cd cmake-.2.8.4
./configure 等一会,时间有点长
gmake && gmake install
tar zxf mysql-..
cd mysql
yum install cmake -y
yum install gcc gcc-c++(没安装会报错:
CMake Error at /usr/share/cmake/Modules/CMakeCXXInformation.cmake:17 (GET_FILENAME_COMPONENT):
get_filename_component called with incorrect number of arguments
) make ncurses-devel bison(必须安装,否则报
Warning: Bison executable not found in PATH
-- Configuring incomplete, errors occurred!
)
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/lnmp/mysql -DMYSQL_DATADIR=/usr/local/lnmp/mysql/data -DMYSQL_UNIX_ADDR=/usr/local/lnmp/mysql/data/mysql.sock -DWITH_MYISAM_STORAGE_ENGINE=1 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DEXTRA_CHARSETS=all
如果cmake 的过程中出错,则需删除 CMakeCache.txt 缓存文件
cmake完后,会警告Googletest没有安装,这个不用管;
make & make install 编译时间也会很长
重新编译时,需要清除旧的对象文件和缓存信息
make clean
rm -f CMakeCache.txt
cd /usr/local/lnmp/mysql/support-file/
cp my-large.cnf /etc/my.cnf #根据你的主机内存复制mysql配置文件
cp mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
cd /usr/local/lnmp/
useradd -u 27 -M mysql #-M表示不创建家目录
chown mysql.mysql mysql/ -R
cd /usr/local/lnmp/mysql/scripts/
./mysql_install_db --user=mysql --basedir=/usr/local/lnmp/mysql/ --datadir=/usr/local/lnmp/mysql/data/ 初始化数据库
ll /usr/local/lnmp/myslq/data 此时就有一些初始化文件生成drwxr-xr-x. 2 mysql mysql 4096 Jul 12 12:13 mysql
-rw-rw----. 1 mysql mysql 27813 Jul 12 12:13 mysql-bin.000001
-rw-rw----. 1 mysql mysql 995349 Jul 12 12:13 mysql-bin.000002
-rw-rw----. 1 mysql mysql 38 Jul 12 12:13 mysql-bin.index
drwx------. 2 mysql mysql 4096 Jul 12 12:13 performance_schema
drwxr-xr-x. 2 mysql mysql 4096 Jul 12 12:10 test
cd /usr/local/lnmp/mysql
chown root . -R
chown mysql data -R
/etc/init.d/mysqld start
此时会显示
Starting MySQL..... SUCCESS!
如果mysql不能正常启动,比如pid文件不存在,先把mysql相关目录文件删除,再重新编译
ll /usr/local/lnmp/mysql/data
会有这个文件生成
srwxrwxrwx. 1 mysql mysql 0 Jul 7 08:20 mysql.sock
chkconfig --level 3 mysqld on
cd
vi .bash_profile
在PATH后面添加成下面的样子:
PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin
source .bash_profile
echo $PATH
ln -s /usr/local/lnmp/mysql/lib /usr/local/lnmp/mysql/lib64
#不然php编译的时候(./configure)找不到mysql的库文件
mysql_secure_installation #按提示完成mysql安全设置,生产环境推荐使用
mysql -pwestos
yum install gperf readline-devel time zlib-devel -y
rpmbuild -tb mysql-5.5.12.tar.gz 将tar 包 编译成rpm 包
使nginx支持php(php-fpm):
nginx本身不能处理PHP,它只是个web服务器,当接收到请求后,如果是php请求,则发给php解释器处理,并把结果返回给客户端。
nginx一般是把请求发fastcgi管理进程处理,fascgi管理进程选择cgi子进程处理结果并返回给nginx。
PHP-FPM是一个PHP FastCGI管理器,是只用于PHP的,可以在 http://php-fpm.org/download下载得到.
PHP-FPM其实是PHP源代码的一个补丁,旨在将FastCGI进程管理整合进PHP包中。必须将它patch到你的PHP源代码中,在编译安装PHP后才可以使用。
新版PHP已经集成php-fpm了,不再是第三方的包了,推荐使用。PHP-FPM提供了更好的PHP进程管理方式,可以有效控制内存和进程、可以平滑重载PHP配置,比spawn-fcgi具有更多有点,所以被PHP官方收录了。在./configure的时候带 –enable-fpm(也可以带上--enable-fastcgi )参数即可开启PHP-FPM。
cd /usr/local/php
cp etc/php-fpm.conf.default etc/php-fpm.conf
修改
vi etc/php-fpm.conf.default etc/php-fpm.conf
修改user及group的值。
修改nginx配置文件以支持php-fpm:
location ~ \.php$ {
root html;
fastcgi_pass 127.0.0.1:9000; #fastcgi默认端口为9000
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
#注意将原先的/scripts$fastcgi_script_name 修改为 $document_root$fastcgi_script_name;否则会报错:
FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream
include fastcgi_params;
}
在/usr/local/nginx/html下创建index.php文件:
<?php
phpinfo();
?>
启动php-fpm:
/usr/local/php/sbin/php-fpm (手动打补丁的启动方式/usr/local/php/sbin/php-fpm start)
启动nginx:
/usr/local/nginx/sbin/nginx
安装nginx 处理php网页时,需安装php 和fastcgi。
nginx 处理jsp网页时,需安装jdk(java)和tomcat,由tomcat处理jsp网页。
然后由nginx 同时支持 静态网页,php网页,jsp网页:
vim /usr/local/lnmp/nginx/conf/nginx.conf
location / {
root html; #nginx处理静态网页
index index.html index.htm;
}
location ~ \.php$ {
root html; #将php网页交给9000端口的程序处理
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
include fastcgi.conf; 如果不修改此处,则php网页打不开
}
location ~ \.jsp$ {
proxy_pass http://127.0.0.1:8080; #将jsp网页交给8080端口的程序处理,tomcat 处理jsp网页的默认端口是8080,并且client访问时不用在IP后面添加端口号。
}
curl -I taobao.com 查看server所使用的类型
HTTP/1.1 302 Found
Server: Tengine
Date: Sat, 07 Jul 2012 09:36:25 GMT
Content-Type: text/html
Content-Length: 260
Connection: keep-alive
Location: http://www.taobao.com/
Expires: Sun, 08 Jul 2012 09:36:25 GMT
Cache-Control: max-age=86400
源码安装nginx
yum install pcre-devel openssl-devel -y 支持http的rewrite module,如果没有安装,会报 error: the HTTP rewrite module requires the PCRE library。
下载最新稳定版的nginx
useradd -s /sbin/nologin -M nginx # -M 表示不创建nginx用户家目录
tar zxf nginx-1.2.1.tar.gz
cd nginx-1.2.1
vi auto/cc/gcc 关闭debug
# debug
#CFLAGS="$CFLAGS -g" 注释掉这行,去掉 debug 模式编译,编译以后程序只有几百 k
vi src/core/nginx.h
改成这样:#define NGINX_VER "nginx" 修改此行,去掉后面的“NGINX_VERSION”,为了安全,这样编译后外界无法获取程序的版本号
yum install openssl-devel -y #不安装编译时会报错的
./configure --user=nginx --group=nginx --prefix=/usr/local/lnmp/nginx --with-http_stub_status_module --with-http_ssl_module
make & make install
du -sh /usr/local/lnmp/nginx 如果不关闭debug的话,则生成4.4M的目录
vi /usr/local/lnmp/nginx/conf/nginx.conf
user nginx;
worker_processes 2;
events {
use epoll;
worker_connections 1024;
}
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root html;
index index.html index.htm;
}
location /status {
stub_status on;
access_log off;
}
添加上面3行,当访问192.168.0.55/status 时,会显示如下信息:
Active connections: 1
server accepts handled requests
16 16 168
Reading: 0 Writing: 1 Waiting: 0
}
vi ~/.bash_profile
在PATH后添加 /usr/local/lnmp/nginx/sbin
source ~/.bash_profile
echo $PATH
nginx -t 检测nginx的语法
nginx 启动nginx
ps aux 可以看到总共有3个nginx进程
curl -I localhost
在浏览器中输入 http://192.168.0.55/
nginx -s stop 关闭nginx
nginx 的https功能
编辑nginx的配置文件
vim /usr/local/lnmp/nginx/conf/nginx.conf
server {
listen 443;
server_name localhost;
ssl on;
ssl_certificate cert.pem;
ssl_certificate_key cert.pem;
ssl_session_timeout 5m;
ssl_protocols SSLv2 SSLv3 TLSv1;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
location / {
root html;
index index.html index.htm index.php;
}
}
location / {
root html;
index index.html index.htm index.php;
}
location ~ \.php$ {
root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi.conf;
}
nginx -t
nginx: [emerg] SSL_CTX_use_certificate_chain_file("/usr/local/lnmp/nginx/conf/cert.pem") failed (SSL: error:02001002:system library:fopen:No such file or directory error:20074002:BIO routines:FILE_CTRL:system lib error:140DC002:SSL routines:SSL_CTX_use_certificate_chain_file:system lib)
nginx: configuration file /usr/local/lnmp/nginx/conf/nginx.conf test failed
cd /etc/pki/tls/certs/
make cert.pem
mv cert.pem /usr/local/lnmp/nginx/conf/
nginx -t
nginx: the configuration file /usr/local/lnmp/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/lnmp/nginx/conf/nginx.conf test is successful
nginx -s reload
netstat -anltp | grep :443
此时打开浏览器输入 https://desktop55/phpadmin/index.php 点击获取证书并添加
nginx的虚拟主机
http://wiki.nginx.org/ 此网站有nginx的详细配置
编辑配置文件
vim /usr/local/lnmp/nginx/conf/nginx.conf
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
将main日志功能开启
server {
listen 80;
server_name www.domain1.com;
access_log logs/domain1.access.log main;
location / {
index index.html;
root virtualhosts/domain1.com/;
}
}
cd /usr/local/lnmp/nginx/
mkdir virtualhosts
mkdir domain1.com
mkdir domain2.com
echo www.domain1.com > domain1.com/index.html
echo www.domain2.com > domain2.com/index.html
此时宿主主机 vi /etc/hosts
192.168.0.55 www.domain1.com
192.168.0.55 www.domain2.com
nginx -t
此时在宿主主机的浏览器 http://www.domain1.com
http://www.domain2.com
nginx的负载均衡
编辑配置文件
vim /usr/local/lnmp/nginx/conf/nginx.conf
http {
upstream westos {
server 192.168.0.77:80 weight=1 max_fails=3 fail_timeout=60s;
server 192.168.0.57:80 weight=1 max_fails=3 fail_timeout=60s;
#weight 为服务器的权重,默认是1,权重越大,被访问的概率就越大;如果某台服务器在fail_timeout时间内出现了max_fail 次连接失败,则nginx会认为那个服务器已经挂了。
}
server {
listen 80;
server_name www.westos.org;
location / {
index index.html;
proxy_pass http://westos;
}
}
nginx -t
nginx -s reload
开启另外两太主机的apache,并在宿主机上 vim /etc/hosts
192.168.0.55 www.westos.org (前端机)
打开宿主机的浏览器 www.westos.org 然后刷新,再停止后端机的apache
apache 与 nginx 的压力测试:
ab redhat自带的压力测试工具
webbench 需下载的压力测试工具
ab -c 1000 (发1000次) -n 1000 (并发1000次) http://192.168.0.57/index.html 测试apache的
ab -c 1000 -n 1000 http://192.168.0.55/index.html 测试nginx的
没有优化时,nginx是apache的3到4倍,优化后大概为10倍
下载webbench后,解压
yum install ctags -y
mkdir -p /usr/local/man/man1 (也可不用创建)
cd webbench-1.5
make && make install
ll /usr/local/bin/webbench
webbench -c 3000 (发3000次) -t 10 (10秒) http://192.168.0.57/index.html
webbench -c 3000 -t 10 http://192.168.0.55/index.html
安装php:
下载libiconv-1.13.1.tar.gz #加强系统对支持字符编码转换的功能
libmcrypt-2.5.8.tar.bz2
mhash-0.9.9.9.tar.gz #mcrypt,mhash是php加密算法扩展库
mcrypt-.26.8.tar.gz
tar zxf libiconv..
cd libiconv
./configure --libdir=/usr/local/lib64
make && make install
tar jxf libmcrypt..
cd libmcrypt..
./configure --libdir=/usr/local/lib64
make && make install
cd libltdl
./configure --libdir=/usr/local/lib64 --enable-ltdl-install
make && make install
tar jxvf mhash..
cd mhash..
./configure --libdir=/usr/local/lib64
make && make install
ldconfig /usr/local/lib64 #为了解决 mcrypt 执行./configure 时报错的:configure: error: ***libmcrypt was not found。如果ldconfigure后还是报错,则如下编辑ld.so.conf
vim /etc/ld.so.conf #实现开机加载,使用动态装入器装载找到库文件
/usr/local/lib64 添加次行
tar zxf mcrypt.. #上面的libmcrypt,mhash是mcrypt的依赖包
cd mcrypt..
./configure --libdir=/usr/local/lib64 #./configure时可能会报这个错:/bin/rm: cannot remove `libtoolT’: No such file or directory 直接忽略。 或者报这个错:
configure: error: *** libmcrypt was not found,则需 ldconfig /usr/local/lib64
(最近安装一些库文件,这样可以重新加载库文件)
vim /etc/ld.so.conf #实现开机加载,使用动态装入器装载找到库文件
/usr/local/lib64 添加次行
make && make install
yum install net-snmp-devel curl-devel libxml2-devel libpng-devel libjpeg-devel freetype-devel gmp-devel -y
下载php-5.3.6
tar zxf php..
cd php..
./configure --prefix=/usr/local/lnmp/php --with-config-file-path=/usr/local/lnmp/php/etc --with-mysql=/usr/local/lnmp/mysql/ --with-mysqli=/usr/local/lnmp/mysql/bin/mysql_config
--with-openssl --with-snmp --with-gd --with-zlib --with-curl(没有) --with-libxml-dir --with-png-dir --with-jpeg-dir
--with-freetype-dir --without-pear --with-gettext --with-gmp(没有) --enable-inline-optimization --enable-soap
--enable-ftp --enable-sockets --enable-mbstring --enable-fpm --with-fpm-user=nginx --with-fpm-group=nginx --with-libdir=lib64 --with-mcrypt --with-mhash
make ZEND_EXTRA_LIBS='-liconv' #稍等,时间有点长.Zend Optimizer用优化代码的方法来提高PHP 4.0应用程序的执行速度.Zend引擎是一个开源脚本引擎.(没有安装前面那4个软件包,编译时报找不到liconv的错)
make install
wget http://pear.php.net/go-pear.phar #支持php的扩展与应用库功能,它是一个PHP扩展及应用的一个代码仓库
/usr/local/lnmp/php/bin/php go-pear.phar 或在~/.bash_profile 中的PATH后添加/usr/local/lnmp/php/bin/ source ~/.bash_profile
php go-pear.phar #添加后就可以直接执行php命令了,安装go-pear.phar
cd php-5.3.6
cp php.ini-production /usr/local/lnmp/php/etc 拷贝php的配置文件
cd /usr/local/lnmp/php/etc/
mv php.ini-production php.ini
vim php.ini
cgi.fix_pathinfo=0 大概842行,防止Nginx文件类型错误解析漏洞
date.timezone = Asia/Chongqing 843行
cp php-fpm.conf.default php-fpm.conf php-fpm的配置文件
vim php-fpm.conf
pid = run/php-fpm.pid 大概25行
pm.max_children = 50 152行
pm.start_servers = 20 157行
#在生产环境中一定要做压力测试,找到最合适的进程数组合
pm.min_spare_servers = 5 162行
pm.max_spare_servers = 35 167行
pm.max_requests = 500 173行
cd php-5.3.6/sapi/fpm
cp init.d.php-fpm /etc/init.d/php-fpm
chmod +x /etc/init.d/php-fpm
/etc/init.d/php-fpm start
ps aux 默认启动20个进程
vim /usr/local/lnmp/nginx/conf/nginx.conf
location ~ \.php$ {
root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
include fastcgi.conf;
}
如果想要用反向代理,则
location ~ \.php$ {
proxy_pass http://192.168.235; 将php网页交给192.168.0.235 处理
}
location / {
root html;
index index.html index.htm index.php;
}
cd /usr/local/lnmp/nginx/html/
vi index.php
<?php
phpinfo();
?>
在浏览器中输入 desktop55/index.php
下载最新版的phpMyAdmin-3.4.2
tar jxf phpMyAdmin.. -C /usr/local/lnmp/nginx/html/
cd /usr/local/lnmp/nginx/html/
mv phpMyAdmin.. phpadmin
cd phpadmin
cp config.sample.inc.php config.inc.php
vi config.inc.php
$cfg['blowfish_secret'] = 'westos'; /* YOU MUST FILL IN THIS FOR COOKIE AUTH! */
php 模块扩展:
下载memcached-1.4.5.tar.gz
memcache-2.2.5.tgz
eaccelerator-0.9.6.tar.bz2
yum install libevent-1.4.13.1.el6.x86_64.rpm 不行的话用rpm安装
将optional部分加到dvd.repo中
yum install libevent-devel -y 不行的话用rpm安装
tar zxf memcached-1.4.5 后台软件包
cd memcached-1.4.5
./configure
make && make install
cd
memcached -u root -m 50 -d 以root用户身份占50M内存在后台运行memcache
ps aux
netstat -antlp
tar vxf memcache-2.2.5.tgz 功能模块软件包,以支持某些服务的memcache,如php
cd memcache..
phpize 定义安装环境,并生成一些数据,如configure
ls
./configure
make && make install
cd /usr/local/lnmp/php/etc/
vim php.ini
extension=memcache.so 大概在931行,使php支持memcache
/etc/init.d/php-fpm reload 平滑加载php
然后在浏览器 http://desktop55/index.php 找memcache 模块
cd memcache-2.2.5
cp memcache.php /usr/local/lnmp/nginx/html/
cd /usr/local/lnmp/nginx/html/
vim memcache.php memcache的管理页面
define('ADMIN_USERNAME','admin'); memcache管理页面的用户名和密码
define('ADMIN_PASSWORD','westos');
$MEMCACHE_SERVERS[] = '192.168.0.55:11211'; memcache服务器ip地址
#$MEMCACHE_SERVERS[] = 'mymemcache-server2:11211'; // add more as an array
然后在浏览器 http://desktop55/memcache.php
输入 用户名和密码 就可以打开图形化的memcache
下载memcached-1.4.5.tar.gz
memcache-2.2.5.tgz
eaccelerator-0.9.6.tar.bz2
yum install libevent-1.4.13.1.el6.x86_64.rpm #不行的话用rpm安装
将optional部分加到dvd.repo中
yum install libevent-devel -y 不行的话用rpm安装
tar zxf memcached-1.4.5
cd memcached-1.4.5
./configure
make && make install
cd
memcache -u root -m 50 -d
ps aux
netstat -antlp
tar jxf memcache-2.2.5.tgz
cd memcache..
phpize
ls
./configure
make && make install
cd /usr/local/lnmp/php/etc/
vim php.ini
extension=memcache.so 大概在931hang
然后在浏览器 http://desktop55/index.php 找memcache 模块
cd memcache-2.2.5
cp memcache.php /usr/local/lnmp/nginx/html/
vim memcache.php
define('ADMIN_USERNAME','admin'); // Admin Username
define('ADMIN_PASSWORD','westos'); // Admin Password
$MEMCACHE_SERVERS[] = '192.168.0.55:11211'; // add more as an array
#$MEMCACHE_SERVERS[] = 'mymemcache-server2:11211'; // add more as an array
然后在浏览器 http://desktop55/memcache.php
输入 用户名和密码 就可以打开图形化的memcache
yum install httpd php -y
下载eaccelerator-0.9.6.tar.bz2
cd eaccelerator-0.9.6
phpize 如果此时没有phpize这个命令,则需安装一下两个包
php-devel-5.3.3-3.el6_2.8.x86_64.rpm
php-eaccelerator-0.9.6.1-1.el6.x86_64.rpm
安装好了之后就有phpize这个命令了
which phpize
./configure --with-php-config=/usr/local/lnmp/php/bin/php-config
make
make install
vim /usr/local/lnmp/php/etc/php.ini
extension=eaccelerator.so 添加次行,大概933行
/etc/init.d/php-fpm reload
此时用浏览器访问 192.168.0.235/index.php 可以看到eaccelerator支持php加速
cp control.php /usr/local/lnmp/nginx/html/
vim /usr/local/lnmp/nginx/html/control.php
$auth = true;
$user = "admin";
$pw = "westos"; 修改eaccelerator 的网页管理密码
/etc/init.d/php-fpm reload
ll /var/log/httpd 日志目录
-rw-r--r--. 1 root root 0 Jul 14 02:52 eaccelerator_log
打开浏览器 http://desktop53/control.php
输入用户名和密码后就会显示加速控制面板
下载ImageMagick-6.6.9-9.tar.gz
tar zxf ImageMagick..
cd ..
./configure
make && make install
下载imagick-3.0.0.tgz
tar zxf imagick..
cd ..
phpize 后会生成configure
./configure
make && make install
ll /usr/lib64/php/modules/
cd /etc/php.d
vim imagick.ini
extension=imagick.so
/etc/init.d/httpd restart
打开浏览器 http://desktop53/ 看是否有imagick模块
yum install php-mysql -y 使php支持mysql