Tengine 的安装与使用

本文详细介绍了在CentOS环境下安装并配置Tengine服务器的过程,包括依赖安装、编译与安装步骤,以及如何调整配置文件以优化服务器性能。此外,还涉及了健康监测配置、集群状态信息查看等高级功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

0. 环境和参考文档

centos-6.5
Tengine 官网

1. 安装依赖

yum -y groupinstall "Development tools"
yum -y groupinstall "Server Platform Development"
yum -y install pcre-devel

## 编译时候提示安装的依赖
yum install -y libxslt-devel
yum install -y gd-devel
yum install -y lua-devel

## GeoIP  用户访问来源
cd /usr/local/src
wget http://pkgs.repoforge.org/geoip/geoip-devel-1.4.6-1.el6.rf.x86_64.rpm
wget http://pkgs.repoforge.org/geoip/geoip-1.4.6-1.el6.rf.x86_64.rpm

rpm -ivh geoip-devel-1.4.6-1.el6.rf.x86_64.rpm
rpm -ivh geoip-1.4.6-1.el6.rf.x86_64.rpm

添加Tengine的运行时用户

useradd -r tengine

编译安装

./configure \
--prefix=/usr/local/tengine \
--sbin-path=/usr/local/tengine/sbin/tengine \
--conf-path=/usr/local/tengine/conf/tengine.conf \
--error-log-path=/usr/local/tengine/logs/error.log \
--http-log-path=/usr/local/tengine/logs/access.log \
--pid-path=/var/run/tengine/tengine.pid \
--lock-path=/var/lock/tengine.lock \
--user=tengine \
--group=tengine \
--with-http_ssl_module \
--enable-mods-shared=all \
--dso-path=/usr/local/tengine/dso \
--without_ngx_http_lua_module

将启动脚本引入环境变量

vim /etc/profile.d/tengine.sh

export PATH=/usr/local/tengine/sbin:$PATH

reboot

配置

vim /usr/local/tengine/conf/tengine.conf
## 设置开启的worker数量为auto  (global context)  `cat /proc/cpuinfo`
worker_processes auto;
## 绑定cpu亲缘   (global context)
worker_cpu_afinity auto;
## 定义每个worker进程可以打开的文件句柄参数  (global context)
worker_rlimit_nofile 51200
## 设置每个worker的最大连接数 (events context)
worker_connections 51200

启动 | 停止tengine

tengine -c /usr/local/tengine/conf/tengine.conf
tengine -s stop

做个压力测试

碰到 apr_socket_recv: Connection reset bu peer (104) 错误的解决

ulimit -n 51200

开始测试
/usr/local/apache-2.2.27/bin/ab -c 2000 -n 20000 http://192.168.1.101/index.html
在被测机器使用 top htop vmstat 查看cpu负载和wa
vmstat 1 看cpu wa 数值

开启Tengine的健康监测

需要动态的加载sysguard模块
这样当cpu负载到达1.1之后, Tengine停止服务,并将请求转发至loadlimitaction

## server http context

dso {
    ngx_http_sysguard_module.so;
}

http {
    sysguard on;
    sysguard_load load=1.1 action=/loadlimit;

    server {
        location /loadlimit {
            return 503;
        }
    }
}

集群中upstream 的健康状态监测配置

http {
    upstream cluster1 {
        # simple round-robin
        consistent_hash $request_uri;

        server 192.168.0.1:80 id=1001;
        server 192.168.0.2:80 id=1002;

        check interval=3000 rise=2 fall=5 timeout=1000 type=http;
        check_http_send "HEAD / HTTP/1.0\r\n\r\n";
        check_http_expect_alive http_2xx http_3xx;
    }

    server {
        listen 80;

        location /1 {
            proxy_pass http://cluster1;
        }
        location /status {
            check_status;
            access_log   off;
        }
    }
}

查看集群状态信息

http://127.0.0.1/status
检查失败的图片

### Tengine 安装配置教程 #### 准备工作 为了顺利安装 Tengine,需先确保服务器上已安装必要的开发工具和库文件。对于基于 Red Hat 的系统,可以通过以下命令来完成这些依赖项的安装: ```bash yum install gcc openssl-devel pcre-devel zlib-devel -y ``` 这一步骤会安装 C 编译器以及 OpenSSL、PCRE 和 Zlib 库的相关头文件和发展环境。 #### 解压源码包 假设已经获取到了 `tengine-3.0.0.tar.gz` 文件,则可以使用如下命令将其解压缩到当前目录下: ```bash tar -zxvf tengine-3.0.0.tar.gz ``` 此操作将会创建一个名为 `tengine-3.0.0` 的新文件夹,其中包含了所有的源代码文件[^4]。 #### 配置并编译 进入刚刚解压出来的文件夹内执行配置脚本,并指定安装路径为 `/usr/local/tengine` 。同时开启多线程支持加速编译过程(-j参数后的数字代表并发数): ```bash cd tengine-3.0.0/ ./configure --prefix=/usr/local/tengine && make -j4 && make install ``` 上述指令不仅设置了最终程序存放的位置,还完成了整个项目的构建部署工作[^2]。 #### SSL 设置 (可选) 如果计划启用 HTTPS 协议提供服务的话,还需要进一步设置SSL证书。编辑位于 `/usr/local/tengine/conf/nginx.conf` 中的服务定义部分,加入类似下面这样的配置行指向实际存在的公钥(.crt)位置: ```nginx server { listen 443 ssl; server_name localhost; ssl_certificate /usr/local/tengine/conf/ssl/yourdomain_ssl.crt; } ``` 注意替换掉示例中的域名(`localhost`)及证书路径(/usr/local/tengine/conf/ssl/yourdomain_ssl.crt),使其匹配自己的实际情况[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值