liujia 发布的文章

在Debian 8 系统里设置apache web的虚拟主机

云友“bokie ”提到,不想让他人的域名访问到自己ECS服务器上的站点内容。

因为安装Apache后,在浏览器地址栏里输入ECS的公网地址,访问到的页面是默认站点的内容,如果这时有他人的域名解析到这个公网IP地址,也会访问到相同的内容。

本例环境:Debian 8,通过apt-get安装了apache web,yun.anqun.org 和 portal.anqun.org 两个域名均解析到了ECS的公网IP地址:121.43.110.72

过程:

1.打开apache的虚拟主机配置文件目录,/etc/apache2/sites-enabled ,里边有一个默认站点的配置文件,000-default.conf,内容如下:

<VirtualHost *:80>
        # The ServerName directive sets the request scheme, hostname and port that
        # the server uses to identify itself. This is used when creating
        # redirection URLs. In the context of virtual hosts, the ServerName
        # specifies what hostname must appear in the request's Host: header to
        # match this virtual host. For the default virtual host (this file) this
        # value is not decisive as it is used as a last resort host regardless.
        # However, you must set it for any further virtual host explicitly.
        #ServerName www.example.com
        ServerAdmin webmaster@localhost
        DocumentRoot /var/www/html
        # Available loglevels: trace8, ..., trace1, debug, info, notice, warn,
        # error, crit, alert, emerg.
        # It is also possible to configure the loglevel for particular
        # modules, e.g.
        #LogLevel info ssl:warn
        ErrorLog ${APACHE_LOG_DIR}/error.log
        CustomLog ${APACHE_LOG_DIR}/access.log combined
        # For most configuration files from conf-available/, which are
        # enabled or disabled at a global level, it is possible to
        # include a line for only one particular virtual host. For example the
        # following line enables the CGI configuration for this host only
        # after it has been globally disabled with "a2disconf".
        #Include conf-available/serve-cgi-bin.conf
</VirtualHost>

其中没有设置ServerName,且提示这个站点将作为默认站点,即如果当请求域名不存在时,将显示该站点的内容。

2.现在在 /etc/apache2/sites-enabled 目录里,新创建一个虚拟站点 yun.anqun.org 的配置文件 111-yun_anqun_org.conf ,简化后的内容如下:

<VirtualHost *:80>
        ServerName yun.anqun.org
        DocumentRoot /var/www/html/yun.anqun.org
</VirtualHost>

3.保存后重启apache2服务,在浏览器里分别访问 http://yun.anqun.org/ , http://portal.anqun.org/, http://121.43.110.72/ ,结果显示,后两个网址访问到的都是默认站点的内容

bbs-aliyun-dongshan3-305413-1.png

bbs-aliyun-dongshan3-305413-2.png

bbs-aliyun-dongshan3-305413-3.png

所以,如果想不让他人的域名访问到自己的站点内容,可将默认站点设置为其它内容(或空白)即可。

在 Windows 2008 R2 64位系统为 wampserver apache 不同网站配置不同SSL证书(SNI)

有云友 提问,想为 wampserver 套件里的 apache 配置SSL证书安全访问。

环境:Windows 2008 R2 64位中文系统 , wampserver2.5-Apache-2.4.9-Mysql-5.6.17-php5.5.12-64b

过程:

1.安装好wamp,本例是安装到 C:\wamp 且测试可用,启用 mod_ssl模块
bbs-aliyun-dongshan3-305369-1.png

bbs-aliyun-dongshan3-305369-2.png

2.将下载好的证书放到 apache 目录下,如我将 yun.anqun.org 的SSL证书保存在 C:\wamp\bin\apache\apache2.4.9\conf\ssl\yun\ 里

3.编辑 httpd.conf 配置文件(C:\wamp\bin\apache\apache2.4.9\conf\httpd.conf),将约在530行的,关于ssl配置的文件启用;
bbs-aliyun-dongshan3-305369-3.png

4.编辑 httpd-ssl.conf 文件,按实际情况配置虚拟主机的ssl内容,如本例里的 yun.anqun.org 及 portal.anqun.org 的简要配置内容如下(如果apache未加载mod_socache_shmcb块,还需要先注释掉SSLSessionCache的设置,约在第73行):
bbs-aliyun-dongshan3-305369-4.png

5.保存配置文件后,重启apache,在Chrome浏览器里测试访问,显示结果正常
bbs-aliyun-dongshan3-305369-5.png

bbs-aliyun-dongshan3-305369-6.png

在 Debian 8 系统 为 tomcat8 配置https站点访问

在“云栖问答 ”里看到有人提到在tomcat里配置https访问时,可能会遇到问题,所以写此帖。

环境:“经典网络”类型ECS,Debian 8系统,Tomcat 8,JDK 1.7

过程:

1.安装相应的软件或组件,
apt-get install default-jdk tomcat8 tomcat8-examples
bbs-aliyun-dongshan3-305110-1.png

2.将在阿里云申请的,适合tomcat的证书文件上传到合适的目录,如本例是保存在:/etc/tomcat8/cert/213949634960268.pfx

3.编辑 tomcat 的配置文件 /etc/tomcat8/server.xml ,添加相应的https访问配置内容,如本例约在第92号添加了:

<Connector port="8443"
    protocol="HTTP/1.1"
    SSLEnabled="true"
    scheme="https"
    secure="true"
    keystoreFile="/etc/tomcat8/cert/213949634960268.pfx"
    keystoreType="PKCS12"
    keystorePass="213949634960268"
    clientAuth="false"
    SSLProtocol="TLSv1+TLSv1.1+TLSv1.2"
    />
````
其中关键是port,keystoreFile 和 keystorePass,请根据自己的实际情况修改。因为在Debian里的tomcat默认运行账户是tomcat8,是无权限直接使用443端口的,所以本例的port用8443 
![bbs-aliyun-dongshan3-305110-2.png][2]
 
4.重启tomcat服务 
systemctl restart tomcat8
 
6.在火狐浏览器访问,如 https://yun.anqun.org:8443,测试正常 
![bbs-aliyun-dongshan3-305110-3.png][3] 
 
参考:  
* https://tomcat.apache.org/tomcat-8.0-doc/ssl-howto.html 
* https://confluence.atlassian.com/confkb/permission-denied-error-when-binding-a-port-290750651.html 


  [1]: https://liujia.anqun.org/usr/uploads/2019/06/09/81045930862347.png
  [2]: https://liujia.anqun.org/usr/uploads/2019/06/09/81045765975983.png

在CentOS 7 系统设置使用公钥登录(publickey)

看到云友“鱼鱼鱼鱼啊 ”想设置公钥登录到CentOS系统,所以写此帖。

环境:经典网络类型的ECS,CentOS 7.2系统,远程ssh登录软件为MobaXterm 9.4

过程:

1.在 MobaXterm 软件的 Tools 菜单里点周 MobaKeyGen,生成公/私钥对
bbs-aliyun-dongshan3-304996-1.png

2.点击 Generate 按钮,在生成过程中,会提示您移动鼠标,随机生成创建
bbs-aliyun-dongshan3-304996-2.png

bbs-aliyun-dongshan3-304996-3.png

3.将生成的公钥(public key)复制,粘贴到 ~/.ssh/authorized_keys 中(可先通过mkdir ~/.ssh/ 创建好目录,再vi ~/.ssh/authorized_keys 粘贴 ),请注意要复制完整
bbs-aliyun-dongshan3-304996-4.png

bbs-aliyun-dongshan3-304996-5.png

4.点击 Save private key,保存好私钥
bbs-aliyun-dongshan3-304996-6.png

5.执行以下命令,设置公钥文件和目录的权限
chmod 700 ~/.ssh
chmod 600 ~/.ssh/authorized_keys

6.修改 /etc/ssh/sshd_config 的配置内容,将其中的 PasswordAuthentication 更改为 no
bbs-aliyun-dongshan3-304996-7.png

7.运行 systemctl restart sshd 重启 sshd 服务

8.在MobaXterm的会话管理里,在 Use private key 里选择保存好的私钥
bbs-aliyun-dongshan3-304996-8.png

9.登录测试,成功
bbs-aliyun-dongshan3-304996-9.png

参考:

在 CentOS 6 系统 为 apache 不同网站配置不同SSL证书(SNI)

云友“fjfyfh ”希望能看到在CentOS 6系统里为apache站点配置https的例子,所以写此帖。

环境:CentOS 6.8 64位,apache 2.2

目的:为两个站点(yun.anqun.org, portal.anqun.org)配置https访问。

前提:在阿里云申请下载了相应的SSL证书。

过程:

1.执行以下的命令,安装好apache及mod_ssl模块
yum install httpd mod_ssl
bbs-aliyun-dongshan3-304549-1.png

bbs-aliyun-dongshan3-304549-2.png

2.将站点的SSL证书上传到相应的目录,如本例的 yun_anqun_org.pem 上传到了 /etc/pki/tls/certs/ 目录,yun_anqun_org.key 上传到了 /etc/pki/tls/private/ 目录,需要留意,key文件仅root账户可读写
bbs-aliyun-dongshan3-304549-3.png

3.编辑站点SSL配置文件, /etc/httpd/conf.d/ssl.conf ,如本例,删除了原有默认的SSL 虚拟站点配置内容,增加了以下的SSL 虚拟站点内容:

##
## SSL Virtual Host Context
##
NameVirtualHost *:443
<VirtualHost *:443>
  ServerName yun.anqun.org
  DocumentRoot /var/www/html/yun.anqun.org
  SSLEngine on
  SSLProtocol all -SSLv2
  SSLCipherSuite HIGH:MEDIUM:!aNULL:!MD5
  SSLCertificateFile "/etc/pki/tls/certs/yun_anqun_org.pem"
  SSLCertificateKeyFile "/etc/pki/tls/private/yun_anqun_org.key"
</VirtualHost>
<VirtualHost *:443>
  ServerName portal.anqun.org
  DocumentRoot /var/www/html/portal.anqun.org
  SSLEngine on
  SSLProtocol all -SSLv2
  SSLCipherSuite HIGH:MEDIUM:!aNULL:!MD5
  SSLCertificateFile "/etc/pki/tls/certs/portal_anqun_org.pem"
  SSLCertificateKeyFile "/etc/pki/tls/private/portal_anqun_org.key"
</VirtualHost>

bbs-aliyun-dongshan3-304549-4.png

4.重启apache服务后,在火狐浏览器浏览测试,显示正常
bbs-aliyun-dongshan3-304549-5.png

bbs-aliyun-dongshan3-304549-6.png

参考:https://wiki.apache.org/httpd/NameBasedSSLVHostsWithSNI