大家都知道因为gfw的存在,ghs.google.com经常被墙,所以我们gae用户要找一个可以完美的代替ghs.google.com的方法,所以有了这篇文章,长话短说,我们来进入主题。
一) 权宜的方法:
建立 ghs.yourdomain.com 做 A 指向 可用的 ghs.google.com 可用的IP
然后用 ghs.yourdomain.com 替代 ghs.google.com
缺点是: 在国内,你指向的IP可能随时被封.
优点是: 可以免费实现
二) 完美方案:
在国外申请一台机器, 利用反向代理服务器(如:squid , nginx,squid) 指向 ghs.google.com , 而 ghs.yourdomain.com域名 指向这个反向代理服务器. 我已经验证过,完全可以做到.
缺点: 需要些 Money
优点: 只要google 还在支持的服务,永远可以使用. (当然如果你自己太过分了, 连自己代理服务器的IP都被封了, 那就怪自己吧)
设置过程(这里以nginx为例):
1) 下载 nginx 比如: nginx-0.6.31.tar.gz
2) tar -zxf nginx-0.6.31.tar.gz
3) cd nginx-0.6.31
4) ./configure --prefix=/usr/local/nginx --with-http_realip_module
5) make
6) make install
7) ln -sf /usr/local/nginx/sbin/nginx /usr/sbin/nginx
8 ) 设置反向代理: 编辑 /usr/local/nginx/conf/nginx.conf ,如:
upstream hosts_yourdomain_com { -- 别名可以随便取
server ghs.google.com:80; -- ghs.google.com
}
server {
listen 80;
server_name ghs.yourdomain.com; -- 我自己的 ghs 域名
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
proxy_redirect off;
proxy_set_header Host $host;
proxy_pass http://hosts_yourdomain_com; --- 前面取的别名
proxy_set_header x-real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
9) nginx运行控制
1、检查配置文件有无语法错误 shell> nginx -t
10) 最后将你的实际域名 做 CNAME 指向 ghs.yourdomain.com. 就大功告成了.
补充:
按如下配置可以解决共享范围的控制问题: 假设限定在 *.abc.com *.efg.com 这两个域名使用 该自建的GHS服务
upstream ghs_google_com { #别名可以随便取,反向代理目的地址: Google 的 GHS
server ghs.google.com:80;
}
server {
listen 80;
server_name *.abc.com *.efg.com; #允许 *.abc.com 和 *.efg.com 通过该反向代理服务器
location / {
proxy_redirect off;
proxy_set_header Host $host;
proxy_pass http://ghs_google_com; #转向到 Google的 GHS
proxy_set_header x-real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
server {
listen 80;
server_name *.com *.cn *.org *.mobi *.tel *.asia *.net *.name *.me *.tv *.cc *.hk *.biz *.info;
location xxxx { #表示非前面允许的域名的其他域名统统禁止通行,此处的"xxxx"是乱写的
#其实可以通过这里指向普通的Web服务(非GHS的服务).
# 于是同一个IP即可以做"自制GHS服务",又可以做其他正常的功能.
}
}