关注idc主机测评和云服务商活动促销动态,同时推荐免费云服务器,便宜vps,香港云主机,美国海外服务器,空间域名ssl证书及cdn网络加速产品

UCloud优刻得全球动态加速PathX产品答疑FAQs

建站运维 laoliublog 146浏览 0评论

了解了UCloud优刻得云计算全球动态加速PathX产品使用指南为什么选择PathXUCloud免费GlobalSSH产品跨国网络加速使用教程UCloud优刻得全球动态加速Pathx苹果审核加速通道UCloud优刻得全球动态加速PathX产品术语名词解释老刘博客这里接着为朋友们介绍在使用PathX过程中常见问题,这些产品答疑FAQs将帮助我们更快上手PathX,体验通畅跨国加速服务。

全球动态加速PathX产品页

加速配置和加速线路的关系

1、带宽共享功能:一个加速线路可以被多个加速配置绑定,这些加速配置共享加速线路的带宽;
2、一个加速配置可以绑定多个加速线路。
3、删除加速配置不会影响加速线路,加速线路仍存在;
4、若加速线路上绑定了加速配置,该加速线路不能删除;若加速线路上无任何加速配置,该加速线路可以删除。

为什么看到大量固定的IP地址在访问源站服务器

这些地址是加速集群出口EIP,起到两个作用:
1、传输业务流量(可通过toa模块获取访问者真实IP)
2、对源站服务器做健康检查
对源站服务器做健康检查是通过TCP三次握手的原理来探测源站可用性,为短连接。

注意:源站相关的云服务商或IDC安全策略,可能对短时间内大量的tcp短连接比较敏感,例如阿里云的安骑士、云盾会在你不知情的情况下误杀这类IP。安全起见,建议在加速线路详情页获得出口EIP列表后 提前加入到云盾白名单内(包括阿里云的CDN厂商信任列表,WAF产品白名单)。

如何获取访问者真实IP?

由于经过加速,在日志中看到的访问者IP全部变为PathX的出口IP。 如果需要获取真实的客户端IP, 可以在你的源站服务器上加载UCloud专有的内核模块,让应用直接获取到源IP,这时候,再去查看日志,就是访问者的真实IP了。
Linux系统
64位的linux系统可运行”modprobe toa”尝试加载模块,成功后无需其他操作。
如提示未找到该模块,可按如下步骤进行手工编译与加载:

1.查看当前内核版本号,确认依赖”kernel -devel、kernel -headers”是否安装以及版本号是否与内核一致(‘uname -r && rpm -qa |egrep ‘kernel -devel|kernel -headers’):
若一致,跳过步骤2,进行toa模块的编译安装
若不一致,如下图:
 需要卸载后进行步骤2操作(rpm -e –nodeps kernel-devel kernel-headers)
若未安装依赖,如下图: 

2.yum搜索是否有与当前内核版本对应的kernel-devel、kernel-headers 若有,则安装对用版本(yum install pkgname-version.x86_64)
若无,如下图

则打开网站 http://rpm.pbone.net 点击左侧SEARCH标签,填入包名+版本号(如:kernel-devel-3.10.0-693.11.6.el7.x86_64),选择对应的系统发行版本(此处为CentOS7),点击搜索
 搜索结果:  或使用谷歌用关键字“rpm.pbone.net kernel-devel-3.10.0-693.11.6.el7.x86_64”搜索  下载后rpm方式安装,kernel-headers的安装同理  确认安装结果(’uname -r && rpm -qa |egrep ‘kernel-devel|kernel-headers’),如下图: 

3.下载linux通用版的源码包,该版本支持Centos 6.9和Centos 7、ubuntu 14.04等绝大多数的linux发行版:

国内:

1
wget http://pathx.ufile.ucloud.com.cn/linux_toa.tar.gz

国外:

1
wget http://toa.ufile.ucloud.com.cn/linux_toa.tar.gz

4.编译加载


1
2
3
4
5
6
yum install -y gcc
tar -zxvf linux_toa.tar.gz
cd linux_toa
make
mv toa.ko /lib/modules/`uname -r`/kernel/net/netfilter/ipvs/toa.ko
insmod /lib/modules/`uname -r`/kernel/net/netfilter/ipvs/toa.ko

toa模块安装验证如下(lsmod |grep toa):

toa模块安装验证

5.添加开机模块自动加载


1
2
echo "insmod /lib/modules/`uname -r`/kernel/net/netfilter/ipvs/toa.ko"
>> /etc/rc.local

nginx 环境下,直接在nginx 日志中查看真实访问者地址 日志路径: /var/log/nginx/access.log

nginx 日志中查看真实访问者地址

apache环境下,直接在apache日志中查看真实访问者地址

日志路径:/etc/httpd/logs/access_log

日志路径:/etc/httpd/logs/access_log

其他web配置环境, 采用同样方法在相关web 日志文件中检查即可。

安装了toa仍然无法查看真实客户端IP

toa原理是从tcp包中取出option字段,解析出真实客户端IP,最后通过内核钩子函数完成替换,服务程序调用的socket库可以通过getpeername方法获取到真实客户端IP。由于toa目前不支持ipv6, 如果源站服务监听了ipv6地址,如golang服务默认监听方式,也会导致无法获取真实客户端IP,需要业务调整服务监听方式。如果必须支持ipv6栈下获取真实客户端IP,请联系我们讨论解决方案。

如果整条链路转发过程中出现了tcp连接截断的情况,分成两段tcp连接。如在rs前使用了七层负载均衡或tcp请求代理模式,就会导致安装toa成功,仍然获取不到真实客户端IP:

1)client ——-> pathx 4层转发 ——— tcp packet (option字段包含:客户端IP ) ——–> 7层负载均衡或tcp请求代理负载均衡 ———-tcp packet (option字段不再包含 客户端IP) ——–> 源站RS(安装toa 不能获取客户端IP)

2)client ——-> pathx 4层转发 ——— tcp packet (option字段包含:客户端IP ) ——–> 源站RS(安装toa 可以获取客户端IP)

3)client——–> pathx 4层转发 ——— tcp packet (option字段包含:客户端IP ) ——–> 4层负载均衡(ulb4开启报文转发 或 AWS NLB开启保留源IP) ———-tcp packet (option字段包含 客户端IP) ——–> 源站RS(安装toa 可以获取客户端IP)

如果使用http协议场景,七层转发 不需要安装toa模块就可以获取真实客户端IP:

4)client——–> pathx 7层转发 ——X-Forwarded-For———> 各类LB ——–> 源站RS(从http header获取客户端IP)

5)client——–> pathx 7层转发 ——X-Forwarded-For———> 源站RS(从http header获取客户端IP)

如何查看PathX的回源IP(靠近源站一侧的转发节点IP)?

请在PathX资源详情页查看,需要在源站设置白名单时可供参考。这些IP在碰到ddos攻击或机房网络裁撤情况下会发生变化。加速域名解析出来的IP是靠近客户端一侧的接入点IP,在发生ddos攻击或机房网络裁撤情况下会发生变化。

非UCloud服务器是否可以使用全球动态加速?

可以,只要是公网路由可达的服务器即可。

网站是否需要备案

1)选择的加速区域在中国大陆地区,当业务域名CName到加速域名后,需要在中华人民共和国工业和信息化部完成相关备案(console设有备案申请入口)。

2)客户端直接使用PathX加速域名是不需要备案的,加速域名已经备案。

3)选择的加速区域在中国大陆地区之外,无论客户端在哪访问都不需要备案。

4)使用PathX作为国内CDN回源海外服务器的加速器时,回源http(s)请求会经过PathX国内机房节点,备案系统会在机房pop点检查http header中host字段保存的域名是否做过备案。虽然此时cname没有解析到加速域名,仍然需要申请备案。

全球动态加速和CDN加速有区别吗?

CDN在边缘节点对资源缓存实现访问提速,缓存的对象为静态媒体资源。全链路在公网上,跨国回源的线路不太稳定。国外领先的CDN厂商对回源网络做了深度优化,受政策影响,在某些地区节点数量有限,需要其他产品辅助。

全球应用加速优化的是从客户端到源站的跨国(洲)网络质量,依托UCloud的专线调度能力,控制丢包和延迟,不支持应用数据缓存,每次请求都会访问源站获取资源数据。适合支付、登陆、聊天、长连接等场景。同时支持websocket,http等应用层协议,在靠近客户端一侧提前终结tcp连接,端到端长连接优化,可以使链路速度大幅提升。

HTTP(s)网站或API场景是否可以使用?

1)可以使用,全球动态加速支持tcp透传回源。在控制台配置 TCP 80或443端口,证书仍然部署在你的业务服务器上,不需要其他设置。

2)如果你的业务场景需要就近Offloading SSL, 用HTTP协议回源,可以使用PathX 7层端口转发中HTTPS-HTTP方式。

3)如果你使用的HTTP(s)请求,源站不方便安装TOA模块 又想获得真实客户端IP,可以使用PathX HTTPS-HTTPS或HTTP-HTTP转发方式。

什么是多地接入?

以中国(多地)到香港的加速为例,创建加速后,华北、华东、华南的用户访问同一个加速域名,但解析出的IP不同,这些IP分别对应pathx在三个地区的入口,也即,不同区域的用户访问pathx加速域名会解析出离用户最近的加速入口IP。

资源使用一段时间后,PathX或GlobalSSH的加速域名+端口突然无法正常访问,而源站+端口可以正常访问

用curl测试一般会报”curl: (56) Failure when receiving data from the peer” 用telnet测试 提示连接成功后,立即收到”Reset By Remote Peer” 重点!重点!重点!用nc测试,则提示连接成功建立。

  1. 检查源站是否有安全策略设置,如阿里云的安骑士(云盾会在用户不做任何配置情况下自动封堵,需要开启白名单IP保护 CDN信任厂商),fail2ban等,若有,可以从console资源详情页获取pathx或globalssh 出口ip加入白名单。
  2. 以上不能解决你的问题,请先提工单咨询你的源站服务器供应商,是否有自动封堵不明来源IP的安全策略。
  3. 检查系统参数设置net.ipv4.tcp_timestamps = 1 net.ipv4.tcp_tw_recycle = 0 net.ipv4.tcp_tw_reuse = 1

开启tcp_tw_resuse足够进行TCP连接的回收(作为客户端压测或向外大量发请求时有效),tcp_tw_recycle由于设计的时间较为早期,并没有考虑NAT技术在如今公网已经普及,会导致经过NAT(诸如网吧、4G、WIFI)用户部分的连接失败。当前这个参数已经基本废弃。提升tcp回收速度,也可以通过减小tcp等待timeout的时间来实现。

源站是否可以修改?

2020年7月开始,PathX加速源站支持修改,在加速配置详情页,可以修改为新的源站IP或域名,原加速域名和端口不变。注意修改源站后,可能会发生短暂的服务中断,需要客户端重连。

pathX欠费回收后是否可以找回?

回收后无法找回。此时资源在我司的资源和计费系统被标记删除,需要重新创建资源。

pathX是否可配置带宽告警?

可在加速线路详情页”告警模板”处配置,支持带宽绝对值和带宽使用率告警,在加速线路详情页和加速配置页,下拉列表可以选择不同加速区域 方便定位带宽占比较高的入口。

PathX的限流措施

PathX按购买带宽限流,当实时带宽(出向带宽与入向带宽的最大值)超过购买带宽时会触发限流,限流会引起丢包率上升,连接中断等现象发生,当实时带宽低于购买带宽时限流会自动解除。请在线路详情页配置带宽使用率告警。PathX带宽监控数据需要动态采集计算,分布于全球各地机房有1-2分钟的滞后,导致短时间内实际带宽会大幅跑过购买带宽,等到带宽上报完成后下发限流指令会引起严重的丢包情况。

海外SD-WAN是否会支持从海外访问中国大陆地区或从中国大陆地区访问海外的线路?

目前仅支持加速区域和源站均在海外的线路。

加速配置相关能力限制说明

1)加速区域数量:不限制;

2)端口数量:50;

3)4层和七层协议支持情况:http(s) websocket(s), 4层转发可扩展http2, quic, ipsec-vpn, rtmp, rtc等协议,ssl-vpn需要非标支持,不支持ftp访问。

4)4层端口转发:普通集群上,并发连接数限制10000;

5)7层端口转发:普通集群上,单个源IP(客户端)并发限制100,最大并发连接数4000,https请求会低一些;支持选用高性能集群,有需要的可以随时联系我们。

源站域名和源站多个IP,如何处理负载均衡

1) 如果填写的源站域名解析出来多个IP, 每隔30s会对全部源站IP+端口组合(暂时不包括UDP协议端口)做一次健康检查,踢掉健康检查失败的源站节点;

2) 客户端新增的连接请求采用轮询方式在多个源站IP节点间分发;

以上就是老刘博客总结的UCloud优刻得全球动态加速PathX产品答疑FAQs的全部内容,想体验优刻得PathX全球加速产品可以访问UCloud官网PathX产品页>>

转载请注明:老刘博客 » UCloud优刻得全球动态加速PathX产品答疑FAQs

发表我的评论
取消评论
表情