Golang colly爬虫框架如何用_Golang colly教程【进阶】

c.Visit()未触发OnHTML最常见原因是请求被目标站拦截导致403,因Colly默认UA易被拒绝;需设自定义UserAgent、加OnResponse打印状态码、处理重定向、传完整URL、用Limit()控并发、解压gzip、避开JS渲染页、选稳定选择器、用连接池+channel安全存库。为什么 c.Visit() 调了却没触发 OnHTML?最常见原因不是代码写错了,而是请求根本没成功------被目标站拦在第一关。Colly 默认 UA 是 "colly - https://github.com/gocolly/colly",多数网站(尤其是 nginx 前置的)直接 403 拒绝,连 HTML 都不返回,OnHTML 自然不会执行。必须显式设置 c.UserAgent,例如 c.UserAgent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36"加 c.OnResponse(func(r *colly.Response) { log.Println(r.StatusCode, r.Request.URL) }) 确认是否真收到了 200遇到 302 重定向默认不跟,需设 c.AllowURLRevisit = true(否则跳转后 URL 被去重丢弃)c.Visit() 只接受完整 URL(含 https://),传 /page/2 这类相对路径会静默失败并发数设成 c.Async = true 就够了吗?不够,而且非常危险。c.Async = true 只是开启异步模式,底层仍是单协程串行发请求;真正控制并发的是 c.Limit(),不设它等于没并发。默认行为:无 LimitRule → 所有请求排队,等前一个结束才发下一个正确做法:用 c.Limit(&colly.LimitRule{DomainGlob: "*", Parallelism: 4}) 控制最大并行请求数别盲目调高 Parallelism:设到 10+ 容易触发目标站风控,或本地 too many open files 错误不同域名建议分开限流,比如 GitHub Pages 内容静态但反爬严:&colly.LimitRule{DomainGlob: "*.github.io", Parallelism: 1}OnHTML("div.title") 提取不到内容?先查这三件事不是选择器写错,就是你看到的 HTML 和 Colly 拿到的根本不是一回事。浏览器里能看见,不代表服务器返回的就是那个结构。网页可能返回 gzip 压缩内容,但 Colly 默认不解压 → 加 c.OnResponse(func(r *colly.Response) { r.Collector.UnifyUTF8 = true }) 强制 UTF-8 并启用解压JS 渲染的内容(如 React/Vue SPA)Colly 看不见 → 检查源码里有没有 id="__next" 或 data-server-rendered,有就别硬扛,换 Puppeteer选择器太深、依赖属性顺序或空格 → 改用 class 名优先:"h1.post-title" 比 "body > article > header > h1" 更稳调试技巧:在 OnResponse 里打印 string(r.Body[:min(200, len(r.Body))]),确认返回体是不是你预期的 HTML结果存 MySQL 时连接池爆满,怎么安全写入?Colly 回调本身就在 goroutine 里跑,每个 OnHTML 都开个 sql.Open(),几秒内就能打满数据库连接数。 跃问 跃问是由阶跃星辰开发的免费AI智能问答助手,随时帮你智能搜索、高效阅读、识图理解、和你畅聊感兴趣的话题。

相关推荐
2301_803538952 小时前
SQL统计各分组中排名前三的记录_使用窗口函数RANK
jvm·数据库·python
2301_782659182 小时前
如何让按钮悬停时阴影位置保持固定(仅按钮位移)
jvm·数据库·python
weixin_580614002 小时前
如何用 performance.navigation 判断页面刷新并清理缓存
jvm·数据库·python
21439652 小时前
Golang strings.Builder如何用_Golang Builder拼接教程【对比】
jvm·数据库·python
2301_777599372 小时前
mysql如何配置主机缓存_mysql host_cache_size设置
jvm·数据库·python
qq_206901393 小时前
为什么宝塔面板网站无法正常连接外部远程数据库_检查服务器安全组放行端口并开启IP授权
jvm·数据库·python
亚空间仓鼠3 小时前
关系型数据库MySQL(二):高级特性
数据库·sql·mysql
空空潍3 小时前
Miniconda完整安装教程(win版)
python·miniconda
亚空间仓鼠3 小时前
关系型数据库MySQL(五):Galara高可用
数据库·mysql