最新のnginx(> = 1.9.5)を新しいAmazon linuxにインストールしてhttp2を利用しようとしています。ここに記載されている指示に従いました-> http://nginx.org/en/linux_packages.html
次の内容のレポファイル/etc/yum.repos.d/nginx.repo
を作成しました。
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/mainline/centos/7/$basearch/
gpgcheck=0
enabled=1
yum update
とyum install nginx
を実行すると、次のようになります。
nginx x86_64 1:1.8.1-1.26.amzn1 amzn-main 557 k
まだamzn-mainリポジトリから取得しているようです。 nginxの新しいバージョンをインストールするにはどうすればよいですか?
-編集-nginx.repoファイルに "priority = 10"を追加しました。これでyum install nginx
で1.9.15をインストールでき、次の結果が得られます。
Loaded plugins: priorities, update-motd, upgrade-helper
Resolving Dependencies
--> Running transaction check
---> Package nginx.x86_64 1:1.9.15-1.el7.ngx will be installed
--> Processing Dependency: systemd for package: 1:nginx-1.9.15-1.el7.ngx.x86_64
--> Processing Dependency: libpcre.so.1()(64bit) for package: 1:nginx-1.9.15-1.el7.ngx.x86_64
--> Finished Dependency Resolution
Error: Package: 1:nginx-1.9.15-1.el7.ngx.x86_64 (nginx)
Requires: libpcre.so.1()(64bit)
Error: Package: 1:nginx-1.9.15-1.el7.ngx.x86_64 (nginx)
Requires: systemd
You could try using --skip-broken to work around the problem
You could try running: rpm -Va --nofiles --nodigest
AWS Linux2を使用している場合は、AWS "Extras Repository"からnginxをインストールする必要があります。利用可能なパッケージのリストを表示するには:
# View list of packages to install
Amazon-linux-extras list
次のようなリストが表示されます。
0 ansible2 disabled [ =2.4.2 ]
1 emacs disabled [ =25.3 ]
2 memcached1.5 disabled [ =1.5.1 ]
3 nginx1.12 disabled [ =1.12.2 ]
4 postgresql9.6 disabled [ =9.6.6 ]
5 python3 disabled [ =3.6.2 ]
6 redis4.0 disabled [ =4.0.5 ]
7 R3.4 disabled [ =3.4.3 ]
8 Rust1 disabled [ =1.22.1 ]
9 vim disabled [ =8.0 ]
10 golang1.9 disabled [ =1.9.2 ]
11 Ruby2.4 disabled [ =2.4.2 ]
12 nano disabled [ =2.9.1 ]
13 php7.2 disabled [ =7.2.0 ]
14 lamp-mariadb10.2-php7.2 disabled [ =10.2.10_7.2.0 ]
使用 Amazon-linux-extras install
コマンドを使用して、次のようにインストールします。
Sudo Amazon-linux-extras install nginx1.12
執筆時点では、AWS yumリポジトリから入手できるnginxの最新バージョンは1.8です。
今のところ最善の方法は、ソースから新しいバージョンをビルドすることです。
AWS Linux AMIには、必要なビルドツールがすでに含まれています。
たとえば、Nginx 1.10をベースにしています(通常のec2-user
としてログインしていると想定しています。スーパーユーザーの権限が必要な場合は、先頭にSudo
が付きます)
cd /tmp #so we can clean-up easily
wget http://nginx.org/download/nginx-1.10.0.tar.gz
tar zxvf nginx-1.10.0.tar.gz && rm -f nginx-1.10.0.tar.gz
cd nginx-1.10.0
Sudo yum install pcre-devel openssl-devel #required libs, not installed by default
./configure \
--prefix=/etc/nginx \
--conf-path=/etc/nginx/nginx.conf \
--pid-path=/var/run/nginx.pid \
--lock-path=/var/run/nginx.lock \
--with-http_ssl_module \
--with-http_v2_module \
--user=nginx \
--group=nginx
make
Sudo make install
Sudo groupadd nginx
Sudo useradd -M -G nginx nginx
rm -rf nginx-1.10.0
次に、nginxを起動/停止して、ブート時にロードできるように、サービスファイルが必要になります。
上記の設定に一致するものを次に示します。 /etc/rc.d/init.d/nginx
に入れます:
#!/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="/etc/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
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
サービスファイルを実行可能に設定します。
Sudo chmod 755 /etc/rc.d/init.d/nginx
今、あなたはそれを始めることができます:
Sudo service nginx start
起動時に自動的にロードするには:
Sudo chkconfig nginx on
最後に、要件に合わせて/etc/nginx/nginx.conf
を編集し、Sudo service nginx reload
を実行して変更を更新することを忘れないでください。
これらのnginx RPMはAmazon LinuxではなくRHEL7用に構築されているため、エラーが発生します。 Amazon Linuxは、RHEL6、RHEL7、およびFedoraの奇妙なハイブリッドです。 Amazonに連絡して、ディストリビューション用に特別に構築された適切なnginx19 RPMを作成するように依頼する必要があります。
注意してください、あなたが探している1.10はありません。ここでリストを見ることができます
http://nginx.org/packages/mainline/centos/7/x86_64/RPMS/
お先にどうぞ yum update
使用する yum search nginx
使用しているさまざまなバージョンを確認し、特定のバージョンを選択します。
yum search nginx
centos 6で
nginx.x86_64 : A high performance web server and reverse proxy server
nginx16.x86_64 : A high performance web server and reverse proxy server
nginx18.x86_64 : A high performance web server and reverse proxy server
1.6と1.8の2つのバージョンから選択できます。