技能 编程开发 Bright Data SDK升级与迁移指南

Bright Data SDK升级与迁移指南

v20260423
brightdata-upgrade-migration
本指南为开发者提供了一份全面的迁移手册,指导用户在Bright Data生态系统中进行复杂的服务和API升级。内容涵盖了从传统代理到Web Unlocker的切换、从Puppeteer到Scraping Browser的迁移,以及数据API版本的更新。文章提供了详细的步骤、代码示例和回滚流程,确保开发流程平稳过渡。
获取技能
248 次下载
概览

Bright Data Upgrade & Migration

Overview

Guide for migrating between Bright Data products, API versions, and zone configurations. Since Bright Data uses proxy protocols and REST APIs (not versioned SDKs), migrations typically involve changing zone types, proxy endpoints, or API payload formats.

Prerequisites

  • Current Bright Data zone credentials
  • Git for version control
  • Staging environment for testing

Instructions

Step 1: Identify Migration Type

Migration From To Effort
Zone upgrade Web Unlocker v1 Web Unlocker v2 Low
Product switch Residential Proxy Web Unlocker Medium
Browser migration Puppeteer direct Scraping Browser Medium
API migration Datasets v2 Datasets v3 Medium
Full platform Competitor Bright Data High

Step 2: Migrate from Direct Proxies to Web Unlocker

// BEFORE: Raw residential proxy (manual CAPTCHA handling)
const oldProxy = {
  host: 'brd.superproxy.io',
  port: 22225,  // Old residential port
  auth: {
    username: `brd-customer-${CID}-zone-residential_zone`,
    password: OLD_PASSWORD,
  },
};

// AFTER: Web Unlocker (automatic CAPTCHA, fingerprinting)
const newProxy = {
  host: 'brd.superproxy.io',
  port: 33335,  // Web Unlocker port
  auth: {
    username: `brd-customer-${CID}-zone-web_unlocker1`,
    password: NEW_PASSWORD,
  },
};
// Changes: port 22225 → 33335, zone name, password
// Web Unlocker handles CAPTCHAs automatically — remove manual solving code

Step 3: Migrate to Scraping Browser from Puppeteer

// BEFORE: Self-hosted Puppeteer with proxy
import puppeteer from 'puppeteer';
const browser = await puppeteer.launch({
  args: [`--proxy-server=http://brd.superproxy.io:22225`],
});

// AFTER: Bright Data Scraping Browser (managed browser)
import puppeteer from 'puppeteer-core';
const AUTH = `brd-customer-${CID}-zone-scraping_browser1:${PASSWORD}`;
const browser = await puppeteer.connect({
  browserWSEndpoint: `wss://${AUTH}@brd.superproxy.io:9222`,
});
// Changes: launch → connect, local browser → remote WebSocket
// Remove: browser install, proxy args, CAPTCHA solving libraries

Step 4: Migrate Datasets API v2 to v3

// BEFORE: Datasets API v2
const v2Response = await fetch(
  `https://api.brightdata.com/dca/trigger?collector=${collectorId}`,
  { method: 'POST', headers: { 'Authorization': `Bearer ${TOKEN}` }, body: JSON.stringify(input) }
);

// AFTER: Datasets API v3 (current)
const v3Response = await fetch(
  `https://api.brightdata.com/datasets/v3/trigger?dataset_id=${datasetId}&format=json`,
  { method: 'POST', headers: { 'Authorization': `Bearer ${TOKEN}`, 'Content-Type': 'application/json' }, body: JSON.stringify(input) }
);
// Changes: /dca/trigger → /datasets/v3/trigger, collector → dataset_id
// v3 adds: format parameter, webhook delivery, snapshot status polling

Step 5: Migration Checklist

# Create migration branch
git checkout -b migrate/brightdata-zone-upgrade

# Update environment variables
# OLD
BRIGHTDATA_ZONE=residential1
# NEW
BRIGHTDATA_ZONE=web_unlocker1
BRIGHTDATA_ZONE_PASSWORD=new_password

# Test against staging
BRIGHTDATA_ZONE=web_unlocker1_staging npm test

# Verify scraping still works
npm run scrape -- --url https://example.com --dry-run

Rollback Procedure

# Keep old zone active during migration window
# Rollback = switch BRIGHTDATA_ZONE back to old zone name
export BRIGHTDATA_ZONE=old_zone_name
export BRIGHTDATA_ZONE_PASSWORD=old_password

Output

  • Updated zone configuration
  • Migrated proxy code to new endpoints
  • Passing test suite against new zone
  • Old zone kept active for rollback

Error Handling

Issue Cause Solution
407 after migration New zone password not set Update BRIGHTDATA_ZONE_PASSWORD
Different response format Zone type changed Update response parsing
Higher latency Web Unlocker overhead Expected; CAPTCHA solving takes time
Missing data fields API v3 schema change Update TypeScript interfaces

Resources

Next Steps

For CI integration during upgrades, see brightdata-ci-integration.

信息
Category 编程开发
Name brightdata-upgrade-migration
版本 v20260423
大小 5.07KB
更新时间 2026-04-28
语言