您好,登錄后才能下訂單哦!
簡介: Tengine是由淘寶網(wǎng)發(fā)起的Web服務(wù)器項(xiàng)目。它在Nginx的基礎(chǔ)上,針對大訪問量網(wǎng)站的需求,添加了很多高級功能和特性。Tengine的性能和穩(wěn)定性已經(jīng)在大型的網(wǎng)站如淘寶網(wǎng),天貓商城等得到了很好的檢驗(yàn)。它的最終目標(biāo)是打造一個(gè)高效、穩(wěn)定、安全、易用的Web平臺(tái),更多請查看官網(wǎng)。
tengine官網(wǎng):http://tengine.taobao.org/
版本選擇: Tengine-2.2.0.tar.gz
特性
- 繼承Nginx-1.8.1的所有特性,兼容Nginx的配置;
- 動(dòng)態(tài)模塊加載(DSO)支持。加入一個(gè)模塊不再需要重新編譯整個(gè)Tengine;
- 支持HTTP/2協(xié)議,HTTP/2模塊替代SPDY模塊;
- 流式上傳到HTTP后端服務(wù)器或FastCGI服務(wù)器,大量減少機(jī)器的I/O壓力;
- 更加強(qiáng)大的負(fù)載均衡能力,包括一致性hash模塊、會(huì)話保持模塊,還可以對后端的服務(wù)器進(jìn)行主動(dòng)健康檢查,根據(jù)服務(wù)器狀態(tài)自動(dòng)上線下線,以及動(dòng)態(tài)解析upstream中出現(xiàn)的域名;
- 輸入過濾器機(jī)制支持。通過使用這種機(jī)制Web應(yīng)用防火墻的編寫更為方便;
- 支持設(shè)置proxy、memcached、fastcgi、scgi、uwsgi在后端失敗時(shí)的重試次數(shù)
- 動(dòng)態(tài)腳本語言Lua支持。擴(kuò)展功能非常高效簡單;
- 支持按指定關(guān)鍵字(域名,url等)收集Tengine運(yùn)行狀態(tài);
- 組合多個(gè)CSS、JavaScript文件的訪問請求變成一個(gè)請求;
- 自動(dòng)去除空白字符和注釋從而減小頁面的體積
- 自動(dòng)根據(jù)CPU數(shù)目設(shè)置進(jìn)程個(gè)數(shù)和綁定CPU親緣性;
- 監(jiān)控系統(tǒng)的負(fù)載和資源占用從而對系統(tǒng)進(jìn)行保護(hù);
- 顯示對運(yùn)維人員更友好的出錯(cuò)信息,便于定位出錯(cuò)機(jī)器;
- 更強(qiáng)大的防***(訪問速度限制)模塊;
- 更方便的命令行參數(shù),如列出編譯的模塊列表、支持的指令等;
- 可以根據(jù)訪問文件類型設(shè)置過期時(shí)間;
簡介:關(guān)系型數(shù)據(jù)庫管理系統(tǒng),由瑞典MySQL AB公司開發(fā),目前屬于Oracle公司。MySQL最流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),在WEB應(yīng)用方面MySQL是最好的RDBMS(Relational Database Management System,關(guān)系數(shù)據(jù)庫管理系統(tǒng))應(yīng)用軟件之一。MySQL是一種關(guān)聯(lián)數(shù)據(jù)庫管理系統(tǒng),關(guān)聯(lián)數(shù)據(jù)庫將數(shù)據(jù)保存在不同的表中,而不是將所有數(shù)據(jù)放在一個(gè)大倉庫內(nèi),這樣就增加了速度并提高了靈活性。MySQL所使用的SQL語言是用于訪問數(shù)據(jù)庫的最常用標(biāo)準(zhǔn)化語言。MySQL軟件采用了雙授權(quán)政策,它分為社區(qū)版和商業(yè)版,由于其體積小、速度快、總體擁有成本低,尤其是開放源碼這一特點(diǎn),一般中小型網(wǎng)站的開發(fā)都選擇 MySQL 作為網(wǎng)站數(shù)據(jù)庫。由于其社區(qū)版的性能卓越,搭配PHP和Apache可組成良好的開發(fā)環(huán)境。MySQL所使用的SQL語言是用于訪問數(shù)據(jù)庫的最常用標(biāo)準(zhǔn)化語言。由于我們網(wǎng)站數(shù)據(jù)是單獨(dú)放在集群中的,使用的是percon,所以在這里就不在安裝數(shù)據(jù)庫
簡介:PHP(外文名:PHP: Hypertext Preprocessor,中文名:“超文本預(yù)處理器”)是一種通用開源腳本語言。語法吸收了C語言、Java和Perl的特點(diǎn),利于學(xué)習(xí),使用廣泛,主要適用于Web開發(fā)領(lǐng)域。PHP 獨(dú)特的語法混合了C、Java、Perl以及PHP自創(chuàng)的語法。它可以比CGI或者Perl更快速地執(zhí)行動(dòng)態(tài)網(wǎng)頁。用PHP做出的動(dòng)態(tài)頁面與其他的編程語言相比,PHP是將程序嵌入到HTML(標(biāo)準(zhǔn)通用標(biāo)記語言下的一個(gè)應(yīng)用)文檔中去執(zhí)行,執(zhí)行效率比完全生成HTML標(biāo)記的CGI要高許多;PHP還可以執(zhí)行編譯后代碼,編譯可以達(dá)到加密和優(yōu)化代碼運(yùn)行,使代碼運(yùn)行更快,具體請參考官網(wǎng)
PHP官網(wǎng):http://www.php.net/
選擇版本:php-7.0.16.tar.gz 7.0最后一個(gè)版本,最新的則為7.1.2
特性:
使用新版的ZendEngine引擎,帶來了許多新的特性,以下是不完全列表:
性能提升:PHP7比PHP5.6性能提升了兩倍。 Improved performance: PHP 7 is up to twice as fast as PHP 5.6
全面一致的64位支持。 Consistent 64-bit support
以前的許多致命錯(cuò)誤,現(xiàn)在改成拋出異常。Many fatal errors are now Exceptions
移除了一些老的不在支持的SAPI(服務(wù)器端應(yīng)用編程端口)和擴(kuò)展。Removal of old and unsupported SAPIs and extensions
新增了空接合操作符。The null coalescing operator (??)
新增加了結(jié)合比較運(yùn)算符。Combined comparison Operator (<=>)
新增加了函數(shù)的返回類型聲明。Return Type Declarations
新增加了標(biāo)量類型聲明。Scalar Type Declarations
新增加匿名類。Anonymous Classes
centos6.8 mini版本
192.168.10.2X
CPU:2核 MEM:2G DISK:100G
關(guān)閉postfix:/etc/init.d/postfix stop && chkconfig postfix off
關(guān)閉防火墻:/etc/init.d/iptables stop && chkconfig iptables off
關(guān)閉SELINUX:sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
sysctl -p
參數(shù) | 含義 |
net.ipv4.ip_forward = 0 | 打開IP轉(zhuǎn)發(fā)功能 |
net.ipv4.ip_default_ttl = 255 | 數(shù)據(jù)包的生存期 |
net.ipv6.conf.all.disable_ipv6 = 1 net.ipv6.conf.default.disable_ipv6 = 1 | 禁用所有接口的IPv6,禁用單獨(dú)接口:net.ipv6.conf.eth0.disable_ipv6 = 1 |
net.ipv4.conf.default.rp_filter = 1 | 開啟反向路徑過濾 |
net.ipv4.conf.all.arp_ignore = 1 | 通過反向路由回溯進(jìn)行源地址驗(yàn)證(在RFC1812中定義)。 對于單一主機(jī)和stub網(wǎng)絡(luò)路由器推薦使用該選項(xiàng) |
net.ipv4.conf.all.arp_announce = 2 | arp響應(yīng)(本機(jī)ping不通網(wǎng)關(guān)) |
net.ipv4.conf.default.accept_source_route = 0 | 處理無源路由的包 |
kernel.sysrq = 0 | 禁用sysrq鍵(小工具,當(dāng)內(nèi)存不足時(shí),可以通過命令來控制linux) |
kernel.core_uses_pid = 1 | 啟用調(diào)試多線程應(yīng)用程序 |
kernel.msgmnb = 65536 | 所有在消息隊(duì)列中的消息總和的最大值(msgmnb=64k) |
kernel.msgmax = 65536 | 指定內(nèi)核中消息隊(duì)列中消息的最大值(msgmax=64k) |
kernel.shmmax = 2147483648 | 是核心參數(shù)中最重要的參數(shù)之一,用于定義單個(gè)共享內(nèi)存段的最大值,64位linux系統(tǒng): 可取的最大值為物理內(nèi)存值-1byte,建議值為多于物理內(nèi)存的 ,一般取值大于SGA_MAX_SIZE即可,可以取物理內(nèi)存-1byte。例如, 如果為64GB物理內(nèi)存,可取64*1024*1024*1024-1=68719476735 |
kernel.shmall = 471859 | 該參數(shù)控制可以使用的共享內(nèi)存的總頁數(shù)。Linux共享內(nèi)存頁大小為4KB,共享內(nèi)存段的 大小都是共享內(nèi)存頁大小的整數(shù)倍。一個(gè)共享內(nèi)存段的最大大小是 16G,那么需要共享內(nèi)存頁數(shù)是16GB/4KB=16777216KB /4KB=4194304(頁),也就是64Bit系統(tǒng)下16GB物理內(nèi)存,設(shè)置kernel.shmall = 4194304才符合要求(幾乎是原來設(shè)置2097152的兩倍),具體可以設(shè)置為內(nèi)存90% |
vim /etc/profile 最后添加一行
ulimit -u 10000
ulimit -n 1024
ulimit -d unlimited
ulimit -m unlimited
ulimit -s 10240
ulimit -t unlimited
ulimit -v unlimited
wget http://tengine.taobao.org/download/tengine-2.2.0.tar.gz 下載Tengine包
wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz tengine的rewrite功能依賴pcre庫,最新的為8.40
wget http://www.openssl.org/source/openssl-1.0.2.tar.gz安裝ssl,使nginx支持https,最新版本為1.1.0
wget https://downloads.sourceforge.net/project/libpng/zlib/1.2.11/zlib-1.2.11.tar.gz安裝最新zlib 支持壓縮
以上都是nginx使用的,如果有添加在更新即可
安裝依賴:yum install gcc gcc-c++
編譯安裝:./configure --prefix=/usr/local/pcre/ && make && make install
編譯安裝 ./config enable-shared --prefix=/usr/local/openssl/ && make && make test && make install
解壓編譯安裝:./configure --prefix=/usr/local/zlib && make &&make install
groupadd web
useradd -s /sbin/nologin -g web web
./configure --prefix=/usr/local/nginx \
--user=web \
--group=web \
--with-pcre=/root/tar/pcre-8.39 \
--with-openssl=/root/tar/openssl-1.0.2 \
--with-zlib=/root/tar/zlib-1.2.11 \
--with-file-aio \ 啟用file aio支持(一種APL文件傳輸格式)
--with-http_gzip_static_module \ 啟用ngx_http_gzip_static_module支持(在線實(shí)時(shí)壓縮輸出數(shù)據(jù)流)
--with-http_realip_module \ 啟用ngx_http_realip_module支持(這個(gè)模塊允許從請求標(biāo)頭更改客戶端的IP地址值,默認(rèn)為關(guān))
--with-http_stub_status_module \ 啟用ngx_http_stub_status_module支持(獲取nginx自上次啟動(dòng)以來的工作狀態(tài))
make && make install
#!/bin/sh
#
# nginx - this script starts and stops the nginx daemon
#
# chkconfig: - 85 15
# description: Nginx is an HTTP(S) server, HTTP(S) reverse \
# proxy and IMAP/POP3 proxy server
# processname: nginx
# config: /etc/nginx/nginx.conf
# config: /etc/sysconfig/nginx
# pidfile: /var/run/nginx.pid
# Source function library.
. /etc/rc.d/init.d/functions
# Source networking configuration.
. /etc/sysconfig/network
# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit 0
nginx="/usr/local/nginx/sbin/nginx"
prog=$(basename $nginx)
NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf"
[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx
lockfile=/var/lock/subsys/nginx
make_dirs() {
# make required directories
user=`$nginx -V 2>&1 | grep "configure arguments:" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`
if [ -z "`grep $user /etc/passwd`" ]; then
useradd -M -s /bin/nologin $user
fi
options=`$nginx -V 2>&1 | grep 'configure arguments:'`
for opt in $options; do
if [ `echo $opt | grep '.*-temp-path'` ]; then
value=`echo $opt | cut -d "=" -f 2`
if [ ! -d "$value" ]; then
# echo "creating" $value
mkdir -p $value && chown -R $user $value
fi
fi
done
}
start() {
[ -x $nginx ] || exit 5
[ -f $NGINX_CONF_FILE ] || exit 6
make_dirs
echo -n $"Starting $prog: "
daemon $nginx -c $NGINX_CONF_FILE
retval=$?
echo
[ $retval -eq 0 ] && touch $lockfile
return $retval
}
stop() {
echo -n $"Stopping $prog: "
killproc $prog -QUIT
retval=$?
echo
[ $retval -eq 0 ] && rm -f $lockfile
return $retval
}
restart() {
configtest || return $?
stop
sleep 1
start
}
reload() {
configtest || return $?
echo -n $"Reloading $prog: "
killproc $nginx -HUP
RETVAL=$?
echo
}
force_reload() {
restart
}
configtest() {
$nginx -t -c $NGINX_CONF_FILE
}
rh_status() {
status $prog
}
rh_status_q() {
rh_status >/dev/null 2>&1
}
case "$1" in
start)
rh_status_q && exit 0
$1
;;
stop)
rh_status_q || exit 0
$1
;;
restart|configtest)
$1
;;
reload)
rh_status_q || exit 7
$1
;;
force-reload)
force_reload
;;
status)
rh_status
;;
condrestart|try-restart)
rh_status_q || exit 0
;;
*)
echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"
exit 2
esac
chmod 777 /etc/init.d/nginx
ln -s /usr/local/nginx/sbin/nginx /usr/local/bin/nginx
chkconfig nginx on
wget http://cn2.php.net/get/php-7.0.16.tar.gz.asc/from/this/mirror php-7.0.16.tar.gz 最新的為7.1.2 下載穩(wěn)定版本7.0
yum install libxml2 libxml2-devel libcurl-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libmcrypt libmcrypt-devel
./configure --prefix=/usr/local/php \
--with-config-file-path=/usr/local/php/etc \
--with-fpm-user=web \
--with-fpm-group=web \
--with-mysqli \
--with-pdo-mysql \
--with-iconv-dir \
--with-freetype-dir \
--with-jpeg-dir \
--with-png-dir \
--with-zlib \
--with-libxml-dir=/usr \
--with-curl --enable-mbregex \
--without-pear \
--with-gettext \
--with-openssl \
--with-mhash \
--with-xmlrpc \
--enable-xml \
--enable-fpm \
--enable-bcmath \
--enable-shmop \
--enable-sysvsem \
--enable-maintainer-zts \
--enable-inline-optimization \
--enable-pcntl \
--enable-sockets \
--enable-mbstring --with-mcrypt \
--enable-ftp --with-gd \
--enable-gd-native-ttf \
--enable-zip \
--enable-soap \
--disable-rpath \
--disable-ipv6 \
--disable-fileinfo \
make && make test && make install
cp php.ini-development /usr/local/php/lib/php.ini
cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
cp /usr/local/php/etc/php-fpm.d/www.conf.default /usr/local/php/etc/php-fpm.d/www.conf
ln -s /usr/local/php/bin/php /usr/local/bin/php
ln -s /usr/local/php/bin/php-config /usr/local/bin/php-config
ln -s /usr/local/php/bin/phpize /usr/local/bin/phpize
#! /bin/sh
### BEGIN INIT INFO
# Provides: php-fpm
# Required-Start: $remote_fs $network
# Required-Stop: $remote_fs $network
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: starts php-fpm
# Description: starts the PHP FastCGI Process Manager daemon
### END INIT INFO
prefix=/usr/local/php
exec_prefix=${prefix}
php_fpm_BIN=${exec_prefix}/sbin/php-fpm
php_fpm_CONF=${prefix}/etc/php-fpm.conf
php_fpm_PID=${prefix}/var/run/php-fpm.pid
php_opts="--fpm-config $php_fpm_CONF --pid $php_fpm_PID"
wait_for_pid () {
try=0
while test $try -lt 35 ; do
case "$1" in
'created')
if [ -f "$2" ] ; then
try=''
break
fi
;;
'removed')
if [ ! -f "$2" ] ; then
try=''
break
fi
;;
esac
echo -n .
try=`expr $try + 1`
sleep 1
done
}
case "$1" in
start)
echo -n "Starting php-fpm "
$php_fpm_BIN --daemonize $php_opts
if [ "$?" != 0 ] ; then
echo " failed"
exit 1
fi
wait_for_pid created $php_fpm_PID
if [ -n "$try" ] ; then
echo " failed"
exit 1
else
echo " done"
fi
;;
stop)
echo -n "Gracefully shutting down php-fpm "
if [ ! -r $php_fpm_PID ] ; then
echo "warning, no pid file found - php-fpm is not running ?"
exit 1
fi
kill -QUIT `cat $php_fpm_PID`
wait_for_pid removed $php_fpm_PID
if [ -n "$try" ] ; then
echo " failed. Use force-quit"
exit 1
else
echo " done"
fi
;;
status)
if [ ! -r $php_fpm_PID ] ; then
echo "php-fpm is stopped"
exit 0
fi
PID=`cat $php_fpm_PID`
if ps -p $PID | grep -q $PID; then
echo "php-fpm (pid $PID) is running..."
else
echo "php-fpm dead but pid file exists"
fi
;;
force-quit)
echo -n "Terminating php-fpm "
if [ ! -r $php_fpm_PID ] ; then
echo "warning, no pid file found - php-fpm is not running ?"
exit 1
fi
kill -TERM `cat $php_fpm_PID`
wait_for_pid removed $php_fpm_PID
if [ -n "$try" ] ; then
echo " failed"
exit 1
else
echo " done"
fi
;;
restart)
$0 stop
$0 start
;;
reload)
echo -n "Reload service php-fpm "
if [ ! -r $php_fpm_PID ] ; then
echo "warning, no pid file found - php-fpm is not running ?"
exit 1
fi
kill -USR2 `cat $php_fpm_PID`
echo " done"
;;
*)
echo "Usage: $0 {start|stop|force-quit|restart|reload|status}"
exit 1
;;
esac
chkconfig php-fpm on
1.安裝redis擴(kuò)展
phpredis是php的一個(gè)擴(kuò)展,效率是相當(dāng)高有鏈表排序功能,對創(chuàng)建內(nèi)存級的模塊業(yè)務(wù)關(guān)系很有用
wget https://github.com/phpredis/phpredis/archive/php7.zip
unzip php7.zip
cd phpredis
wget https://pecl.php.net/get/mongodb-1.2.6.tgz
tar zxvf mongodb-1.2.6.tgz
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make
make install
編輯php.ini文件,添加extension=mongodb.so
注意:
報(bào)錯(cuò):configure: error: libssl not found!
解決:yum -y install openssl-devel
3.安裝memcache擴(kuò)展
wget https://pecl.php.net/get/memcache-3.0.8.tgz
安裝MYSQL
Percina版本: Percona-Server-5.6.26-74.0-r32f8dfd-el6-x86_64-bundle.tar
獲取地址:https://www.percona.com/downloads/Percona-Server-5.6/Percona-Server-5.6.33-79.0/binary/redhat/6/x86_64/Percona-Server-5.6.33-79.0-r2084bdb-el6-x86_64-bundle.tar
安裝 epel-release-6-8.noarch.rpm libaio-0.3.107-10.el6.x86_64.rpm
安裝依賴關(guān)系 yum install -y gcc gcc-c++ make cmake automake autoconf libxml2 libxml2-devel zlib zlib-devel ncurses ncurses-devel
然后yum jemalloc //tokuDB內(nèi)存分配需要jemalloc支持
Percona-Server-5.6.26-74.0-r32f8dfd-el6-x86_64-bundle.tar 解壓后的安裝順序是:
tar xvf Percona-Server-5.6.26-74.0-r32f8dfd-el6-x86_64-bundle.tar
rpm -ivh Percona-Server-shared-56-5.6.26-rel74.0.el6.x86_64.rpm
rpm -ivh Percona-Server-devel-56-5.6.26-rel74.0.el6.x86_64.rpm
rpm -ivh Percona-Server-client-56-5.6.26-rel74.0.el6.x86_64.rpm
rpm -ivh Percona-Server-server-56-5.6.26-rel74.0.el6.x86_64.rpm
rpm -ivh Percona-Server-tokudb-56-5.6.26-rel74.0.el6.x86_64.rpm
修改系統(tǒng)參數(shù)
echo never > /sys/kernel/mm/redhat_transparent_hugepage/defrag
echo never > /sys/kernel/mm/redhat_transparent_hugepage/enabled
echo never > /sys/kernel/mm/transparent_hugepage/enabled
echo never > /sys/kernel/mm/transparent_hugepage/defrag
建議寫到 /etc/rc.local 中,重啟后也可生效
啟動(dòng)服務(wù):/etc/init.d/mysql start
修改mysql配置文件 vim /etc/my.cnf
添加 default-storage-engine=TokuDB
重啟服務(wù):/etc/init.d/mysql restart
輸入:ps_tokudb_admin --enable -uroot -p 密碼默認(rèn)沒有設(shè)置為空
進(jìn)入mysql,驗(yàn)證:
附件:
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。