OBS NGINX反向代理实现HTTPS自定义域名访问
摘要:本文通过NGINX反向代理实现自定义域名HTTPS协议访问华为云OBS服务,采用均衡负载ELB搭建后台服务增强应用高可用性。
data:image/s3,"s3://crabby-images/ac4cd/ac4cdf94d3ef09c9451ebbce37db08f681c7ced6" alt=""
OBS HTTPS Reverse Proxy
创建ECS并安装NGINX服务
注意:安全组设置需要开放80,443端口,默认网络安全组即可
wget http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
rpm -ivh nginx-release-centos-7-0.el7.ngx.noarch.rpm
yum -y install nginx
systemctl start nginx
systemctl enable nginx
data:image/s3,"s3://crabby-images/d35a2/d35a291fed7c90b02aa1b27ca1d6a5f721eee265" alt=""
http://public ip
证书及秘钥上传
1.秘钥以.key文件结尾文件
2.证书以.crt或者.pem结果文件
3.上传到/usr/local/ssl/(目录可自定义)
data:image/s3,"s3://crabby-images/10590/10590d76c8fa32a8ac33294ea0588b4fe16ebdad" alt=""
配置NGINX
vim /etc/nginx/conf.d/default.conf
server {
listen 80;
listen 443 ssl;
ssl_certificate /usr/local/ssl/domain_name.pem;//replace domain_name to your actual value
ssl_certificate_key /usr/local/ssl/domain_name.key;
#server_name domain_name;
server_name ********;###public ip
#access_log /var/log/nginx/host.access.log main;
location / {
root /home/www/public_html/domain_name/public/;
proxy_pass https://bucketname.endpoint;//the bucket you want to access
index index.html index.htm;
}
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;
ssl_prefer_server_ciphers on;
ssl_session_cache shared:SSL:10m;
ssl_session_timeout 10m;
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#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_params;
#}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
}
检测NGINX配置及设置开机启动
nginx -t
systemctl stop nginx
systemctl start nginx
data:image/s3,"s3://crabby-images/dbf45/dbf451302d3c7090a9394d310f1d53ba6dc16106" alt=""
发送HTTP/HTTPS请求获取OBS数据
http://public ip
https://public ip
data:image/s3,"s3://crabby-images/4f00c/4f00c1eaa66867cd49a6e85a0b46cf0248c34aff" alt=""
data:image/s3,"s3://crabby-images/684d6/684d659739bde5f4ec6007b017efe68e6dad69bc" alt=""
制作镜像,新创建一台ECS服务器
使用ECS-NGINX-S1创建镜像,申请一台服务器,实现两台服务器互相backup
data:image/s3,"s3://crabby-images/b1f3b/b1f3bb6264eaac1d6fb62a75586447b542b7463c" alt=""
创建ELB服务,添加HTTPS监听及后端服务器
1.创建HTTP/HTTPS ELB
2.添加HTTPS监听器
3.添加证书crt,秘钥pem
4.添加后台服务器,设置80端口
data:image/s3,"s3://crabby-images/6c3d0/6c3d017574a3070e0484bab762d5abc972961322" alt=""
data:image/s3,"s3://crabby-images/e8b37/e8b373bea1555cd90c327e6c31cfd140d62fa39c" alt=""
data:image/s3,"s3://crabby-images/c0272/c0272139b6e7395a7fa94afafcfc9891ba8ea57e" alt=""
测试ELB HTTPS请求服务访问OBS服务
data:image/s3,"s3://crabby-images/2b465/2b46516708a1d8723db4a332d13f597c21e3cf66" alt=""