IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> 网站频繁抓取IP被封 -> 正文阅读

[网络协议]网站频繁抓取IP被封

  1. 设置每个页面抓取时间间隔,降低被封概率
     ThreadUtil.sleep(Long.parseLong(Math.random() * Integer.parseInt(LoadPropertyUtil.getConfig("millions_3"))+""));
  2. 购买IP库,随机获取IP抓取数据;将ip放入redis中,每次随机获取放入请求中,如果失效,则从redis库中删除
    //下载页面
    public static String getPageContent(String url){
            //1. 创建HttpClient实例
            HttpClientBuilder builder = HttpClients.custom();
            //CloseableHttpClient client = builder.build();
            CloseableHttpClient client = null;
            /******************设置动态ip***********************/
            //182.90.28.52:80
            RedisUtil redisUtil = new RedisUtil();
            //获取代理ip
            String ip_port = redisUtil.getSet("proxy");
            if(StringUtils.isNotBlank(ip_port)){
                String[] arr = ip_port.split(":");
                String proxy_ip=arr[0];
                int proxy_port=Integer.parseInt(arr[1]);
                //设置代理
                HttpHost proxy = new HttpHost(proxy_ip, proxy_port);
                client =builder.setProxy(proxy).build();
            }
    
            // 2. 根据URL创建HttpGet实例
            HttpGet request = new HttpGet(url);
            String content=null;
            try {
                request.setHeader("User-Agent",USER_AGENT);
                // 执行get请求,得到返回体
                CloseableHttpResponse response = client.execute(request);
               // 实体是在执行包含内容的请求时创建的,或者是在请求成功并使用响应体将结果发送回客户机时创建的
                HttpEntity entity = response.getEntity();
                //将html网页转换为String
                content = EntityUtils.toString(entity);
            }catch (HttpHostConnectException e){
                e.printStackTrace();
                //如果当前ip不可用,从动态代理ip中删除
                redisUtil.deleteSet("proxy",ip_port);
            } catch (ClientProtocolException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }catch (IOException e) {
                e.printStackTrace();
            }
            return content;
        }
  • 部署多个应用分别抓取,降低单节点频繁访问;单个结点轮询或随机抓取不同网站,以下是随机抓取不同视频网站,将顶级域名:url放入到redis中,每次从redis中随机抓取url
    /**
     * Redis url仓库实现类:随机取不同视频网站url,降低单个网站频繁访问
     * @author 小新
     * @create 2021/12/3- 11:37
     */
    public class RandomRedisRepositoryService implements IRepositoryService {
        //顶级域名:redisKey
        HashMap<String,String> hashMap=new HashMap<>();//相当于索引
        RedisUtil redisUtil=new RedisUtil();
        Random random=new Random();
    
        /**
         * 随机获取url
         * @return
         */
        @Override
        public String poll() {
            String[] keyArr = hashMap.keySet().toArray(new String[0]);
            int nextInt = random.nextInt(keyArr.length);
            String key=keyArr[nextInt];
            String value=hashMap.get(key);
            return redisUtil.poll(value);
        }
    
        @Override
        public void addHighLevel(String url) {
            //获取顶级域名
            String topDomain = MatchUtil.getTopDomain(url);
            //根据顶级域名获取redis key
            String redisKey = hashMap.get(topDomain);
            if(redisKey==null){
                redisKey=topDomain;
                hashMap.put(topDomain,redisKey);
            }
            redisUtil.add(redisKey,url);
        }
    
        @Override
        public void addLowLevel(String url) {
            addHighLevel(url);
        }
    }
    

    注:Redis 作为url仓库的好处

  • 1.机器宕机后redis中会保存已有的数据

  • 2.作为公共仓库,多个结点可以同时操作,负载均衡

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-12-04 13:46:48  更:2021-12-04 13:47:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年7日历 -2024/7/6 8:47:21-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码