标签 nginx 下的文章

OneinStack一键建站环境工具:新增 全自动无人值守安装模式

  • 一、工具介绍

在上一篇文章《OneinStack - 一键 Apache/Nginx/PHP/JAVA 建站环境安装脚本 支持 SSL》 中,我们介绍了OneinStack这个建站工具,是一个非错不错的工具。但是安装过程中需要每一步、一次次重复的手动选择是否安装各种环境和组件。相对而言比较繁琐。

刚又去看了下,才发现OneinStack作者又出一个全自动无人值守安装模式,这就比较方便了,一次输入命令即可。

PS:其实是之前没仔细看,才没发现出的这个新模式。233333... SO,就来补充一发了。

下面是官方最新更新日志:

2018-04-21

新增无人值守安装模式,参考:https://oneinstack.com/auto
新增MySQL8.0、Tomcat9、JDK9
新增oneinstack脚本升级./upgrade.sh oneinstack
软件版本更新至最新稳定

  • 二、自动安装模式

地址:https://oneinstack.com/auto 

方法就比较简单了,其实就是将之前的安装过程中要选择的环境、组件之类的这一个过程,简化并提前选择好,直接开始自动运行。

作者根据不同建站需求,设定了几个默认的方案:lnmp、lamp、lnmpa、lnmt、lnmh以及 自定义

自定义安装

自定义,顾名思义,就是根据你自身的需求,自行选择需要的环境和组件来进行安装。

在页面上勾选好apache、nginx建站环境、mysql、php以及所需的对应版本、Pure-FTPd、和各种组件等,设置好密码,就好在页面下方显示出对应命令。登录你的VPS服务器,复制这些命令,回车安装即可,全程无需值守。等待自动安装完成。

  • 三、总结

OneinStack工具,目前看来比较方便的,各种软件的版本也提供的比较多,更新也比较快的。

更多详细使用,请自行到官网选择安装测试。

OneinStack - 一键Apache/Nginx/PHP/JAVA建站环境安装脚本 支持SSL

官网地址:https://oneinstack.com

 

OneinStack包含以下组合

  • lnmp(Linux + Nginx+ MySQL/MongoDB+ PHP)
  • lamp(Linux + Apache+ MySQL/MongoDB+ PHP)
  • lnmpa(Linux + Nginx+ MySQL/MongoDB+ PHP+ Apache):Nginx处理静态,Apache(mod_php)处理动态PHP
  • lnmt(Linux + Nginx+ MySQL/MongoDB+ Tomcat):Nginx处理静态,Tomcat(JDK)处理JAVA
  • lnpp(Linux + Nginx+ PostgreSQL+ PHP)
  • lapp(Linux + Apache+ PostgreSQL+ PHP)
  • lnmh(Linux + Nginx+ MySQL+ HHVM)

支持系统版本

  • CentOS 6~7(包括redhat)
  • Debian 6~9
  • Ubuntu 12~16
  • Aliyun Linux 15.1

特性

  • 持续不断更新,支持交互、无人值守安装
  • 源码编译安装,大多数源码是最新stable版,并从官方网址下载
  • 提供多个数据库版本(MySQL-8.0, MySQL-5.7, MySQL-5.6, MySQL-5.5, MariaDB-10.1, MariaDB-10.0, MariaDB-5.5, Percona-5.7, Percona-5.6, Percona-5.5,AliSQL-5.6,PostgreSQL, MongoDB)
  • 提供多个PHP版本(PHP-7.2,PHP-7.1,PHP-7.0,PHP-5.6, PHP-5.5,PHP-5.4,PHP-5.3)
  • 提供Nginx、Tengine、OpenResty
  • 提供多个Apache版本(Apache-2.4,Apache-2.2)
  • 提供多个Tomcat版本(Tomcat-9,Tomcat-8,Tomcat-7,Tomcat-6)
  • 提供多个JDK版本(JDK-9,JDK-1.8,JDK-1.7,JDK-1.6)
  • 根据自己需求安装PHP缓存加速器,提供ZendOPcache、xcache、apcu、eAccelerator。及php加解密工具ionCube、ZendGuardLoader
  • 根据自己需求安装Pureftpd、phpMyAdmin
  • 根据自己需求安装Memcached、Redis
  • jemalloc优化MySQL、Nginx
  • 提供添加虚拟主机脚本
  • 提供Nginx/Tengine/OpenResty/Apache、PHP、Redis、phpMyAdmin升级脚本
  • 提供本地备、远程(服务器之间rsync)、阿里云OSS、腾讯云COS和又拍云备份脚本
  • 提供CentOS 6、7下HHVM安装

开源软件版本

# Web # DB # PHP
nginx_ver=1.14.0 mysql57_ver=5.7.22 php72_ver=7.2.4
tengine_ver=2.2.2 mysql56_ver=5.6.40 php71_ver=7.1.16
openresty_ver=1.13.6.1 mysql55_ver=5.5.60 php70_ver=7.0.29
apache24_ver=2.4.33 mariadb102_ver=10.2.14 php56_ver=5.6.35
apache22_ver=2.2.34 mariadb101_ver=10.1.32 php55_ver=5.5.38
tomcat9_ver=9.0.7 mariadb100_ver=10.0.34 php54_ver=5.4.45
tomcat8_ver=8.5.30 mariadb55_ver=5.5.59 php53_ver=5.3.29
tomcat7_ver=7.0.86 percona57_ver=5.7.21-20  # JDK
tomcat6_ver=6.0.53 percona56_ver=5.6.39-83.1 jdk9_ver=9.0.4
    jdk18_ver=1.8.0_172
  alisql56_ver=5.6.32-8 jdk17_ver=1.7.0_80
  pgsql_ver=10.3 jdk16_ver=1.6.0_45
  mongodb_ver=3.6.3  
# phpMyAdmin # Jemalloc # Pure-FTPd
phpmyadmin_ver=4.8.0 jemalloc_ver=5.0.1 pureftpd_ver=1.0.47
phpmyadmin_oldver=4.4.15.10    
# Redis # Memcached  
redis_ver=4.0.9 memcached_ver=1.5.7

安装步骤

yum -y install wget screen curl python #for CentOS/Redhat# apt-get -y install wget screen curl python #for Debian/Ubuntuwget http://mirrors.linuxeye.com/oneinstack-full.tar.gz #包含源码,国内外均可下载tar xzf oneinstack-full.tar.gzcd oneinstack #如果需要修改目录(安装、数据存储、Nginx日志),请修改options.conf文件screen -S oneinstack #如果网路出现中断,可以执行命令screen -R oneinstack重新连接安装窗口./install.sh #注:请勿sh install.sh或者bash install.sh这样执行

《安装》

如何添加附加组件?

./addons.sh

《安装》

  • 三、使用说明

如何添加虚拟主机?

./vhost.sh

《安装》

如何删除虚拟主机?

./vhost.sh del

《安装》

如何管理FTP账号?

./pureftpd_vhost.sh

《安装》

如何备份?

./backup_setup.sh # Set backup options 

《安装》

 ./backup.sh # Start backup, You can add cron jobs   # crontab -l # Examples      0 1   * cd ~/oneinstack;./backup.sh  > /dev/null 2>&1 &

如何管理服务?

Nginx/Tengine/OpenResty:

service nginx {start|stop|status|restart|reload|configtest}

MySQL/MariaDB/Percona:

service mysqld {start|stop|restart|reload|status}

PostgreSQL:

service postgresql {start|stop|restart|status}

MongoDB:

service mongod {start|stop|status|restart|reload}

PHP:

service php-fpm {start|stop|restart|reload|status}

HHVM:

service supervisord {start|stop|status|restart|reload}

:hhvm进程交给supervisord管理,了解更多请访问《Supervisor管理hhvm进程
Apache:

service httpd {start|restart|stop}

Tomcat:

service tomcat {start|stop|status|restart}

Pure-Ftpd:

service pureftpd {start|stop|restart|status}

Redis:

service redis-server {start|stop|status|restart|reload}

Memcached:

service memcached {start|stop|status|restart|reload}

如何更新版本?

./upgrade.sh

《安装》

如何卸载?

./uninstall.sh

《安装》

 

Nginx 编译安装http2教程

  1. 前言
    这次为大家带来的是 linux 下 Nginx 的编译安装http2教程!http2与http的区别和优势差异,这里就不再赘述了。相信了解的大都会选择http2,如果你也想尝试或者了解可以参考本教程来尝试安装!

还是老话:新手建议修改任何文件之前,先备份!如造成生产环境或者数据异常,请自行负责!

本次安装环境系统为:CentOS 6.9

  1. 安装准备

同样先更新系统,然后安装必要的依赖库文件等:
yum update
yum upgrade
yum install -y patch libtool gcc gcc-c++ autoconf automake zlib zlib-devel pcre-devel make unzip git wget

  1. 下载 openssl 安装包

这里我们下载官网最新的 1.1.0f 版本:
wget --no-check-certificate https://www.openssl.org/source/openssl-1.1.0f.tar.gz
解压:
tar zxvf openssl-1.1.0f.tar.gz
注意,记住openssl解压文件存放目录,后面编译安装nginx需要用到

  1. 下载 nginx安装包

同样这里我们下载官网最新的nginx 1.13.5版本:
wget -c http://nginx.org/download/nginx-1.13.5.tar.gz
解压并进入解压文件目录:
tar zxvf nginx-1.13.5.tar.gz
nginx-1.13.5

  1. 开始执行编译安装

a.生成/var/cache/nginx 目录,用于存放 Nginx 反向代理的缓存文件
mkdir -p /var/cache/nginx
b.新建nginx的运行用户www(这里用户自行设置)
useradd www
c.选择编译模块,这里我们要安装http2,则选择以下模块(如需要其他模块,请自行选择添加):
http_v2_module
http_ssl_module
d.本次教程的完整编译命令如下:
./configure --prefix=/usr/local/nginx --user=www --group=www --conf-path=/etc/nginx/nginx.conf --with-openssl=/nginx/openssl-1.1.0f --with-http_v2_module --with-http_ssl_module --with-http_gzip_static_module --without-mail_pop3_module --without-mail_imap_module --without-mail_smtp_module --without-http_uwsgi_module --without-http_scgi_module --with-http_stub_status_module --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock --http-client-body-temp-path=/var/cache/nginx/client_temp --http-proxy-temp-path=/var/cache/nginx/proxy_temp --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp --http-scgi-temp-path=/var/cache/nginx/scgi_temp
其中--prefix=/usr/local/nginx表示将nginx编译安装到/usr/local/nginx目录下,--user=www --group=www表示nginx运行的用户和组名称,--conf-path=/etc/nginx/nginx.conf表示nginx配置文件路径
特别注意:--with-openssl=/nginx/openssl-1.1.0f 这里就需要填写前面下载并解压的openssl文件路径,如没有填写或者路径错误,则编译就会出错!
选择好编译的模块后执行以上命令,执行编译!并等待滚屏完成!得到如下图:
20171002120938.jpg
检查各项路径,是否正常!
e.执行安装命令
make && make install
等待安装滚屏结束

  1. 测试是否正常运行

/usr/local/nginx/sbin/nginx -t
如图则表示测试默认配置文件正常
20171002125508.jpg

  1. 查看版本以及具体模块参数等

/usr/local/nginx/sbin/nginx -V
20171002130119.jpg

  1. 将nginx添加到系统服务

在/etc/init.d/目录下创建名为nginx脚本,并写入以下内容(注意修改一些文件的路径和nginx安装配置的一致)


脚本代码开始:

!/bin/sh

. /etc/rc.d/init.d/functions
. /etc/sysconfig/network
[ "$NETWORKING" = "no" ] && exit 0

nginx="/usr/local/nginx/sbin/nginx"
prog=$(basename $nginx)

NGINX_CONF_FILE="/etc/nginx/nginx.conf"

[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx

lockfile=/var/run/nginx.lock

start() {

[ -x $nginx ] || exit 5 
[ -f $NGINX_CONF_FILE ] || exit 6 
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 

killall -9 nginx
}

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


脚本代码结束

  1. 添加脚本文件权限并开启服务

chmod 755 /etc/init.d/nginx
chkconfig --add nginx
Nginx启动,停止,配置测试,重载
service nginx start
service nginx stop
service nginx configtest
service nginx reload

  1. 配置结束。

创建站点开启http2,测试http2是否正常!
A.在nginx配置文件/etc/nginx/nginx.conf中添加一行配置,方便多站点直接加载:
include /usr/local/nginx/vhost/*.conf; (这样直接创建主机站点配置文件,并上传到/usr/local/nginx/vhost/目录下即可直接读取配置)
20171002190317.jpg
B.创建主机站点配置文件www.xxx.com.conf

server {
    listen 443 ssl http2 default_server;
    server_name  www.xxx.com;
    root /data/wwwroot/www.xxx.com
    ssl_certificate      /ssl/cert.pem;
    ssl_certificate_key  /ssl/cert.key;

    ssl_session_cache    shared:SSL:1m;
    ssl_session_timeout  5m;

    ssl_ciphers  HIGH:!aNULL:!MD5;
    ssl_prefer_server_ciphers  on;

    location / {
        root   html;
        index  index.html index.htm;
    }
}

创建并上传到/usr/local/nginx/vhost/目录,重启nginx

C.测试地址
https://myssl.com/http2_check.html
20171002192554.jpg


Warning: in_array() expects parameter 2 to be array, null given in /www/users/HK1590886/WEB/usr/plugins/TopLamuLeimu/Plugin.php on line 85