Proxy Manager FAQs
Find detailed answers to common Proxy Manager questions, including access restriction, port multiplication, IP targeting, and more.
To secure your account and prevent unauthorized access to the Proxy Manager, there are 3 main available workflows:
- Whitelist IPs
- Token based Authentication
- Permission by Email using the Bright data extension
Proxy Manager can connect with the main Bright Data infrastructure using either HTTP or HTTPS connection.
To avoid confusion: This is NOT the connection type to the target URL. To make sure the connection is secure it’s enough to keep Connection to Super Proxy with a default value (HTTP) because the HTTPS requests create an end-to-end encrypted connection with the target site anyway.
In most cases, you don’t even need to touch this config. It may come out useful though when connecting from some territories where traffic to some domains is blocked. In these cases, you need to set it to HTTPS not to allow the global firewall to see the content of your proxies traffic and filter it out based on the target domain
Go to “General” tab and choose the number of ports you want to multiply in the Multiply proxy port drop down
Once you set the number of multiplied ports you need the Proxy Manager will generate the sequential ports identical to the port you configured.
This is a very powerful feature when you need to create many ports with the same settings but only set it once.
With Bright Data you can specify the geolocation and other parameters of the IPs you use for sending traffic. In Proxy Manager it’s especially easy because it take only a few clicks.
Depending on the zone you use you can request IPs only from a specific country (if you use Residential or Datacenter network) or additionally specific carrier (if you use Mobile network).
How to set targeting in Proxy Manager?
To get IPs from a specific location, follow these steps:
- Click on the proxy port that you want to use location-specific IPs
- Go to Targeting tab
- Select country, state, city for choosing a peer in a specific geolocation
- Select ASN or carrier name (only for mobile peers)
Each targeting option requires the proper permissions in your Zone.
If you want to use multiple countries and you don’t want to create a separate proxy port for each country it’s also possible to control the targeting dynamically.
You don’t have to specify the country, state or city targeting in advance using the Targeting tab in the UI. It is possible to pass extra targeting options dynamically (‘on the fly’) along with the request.
curl -x lum-country-br@127.0.0.1:24001 http://lumtest.com/myip.json
The request’s structure is:
curl -x lum-country-<country_iso_code>@<ip>:<port> <destination_url>
The other option for controlling targeting dynamically is by including a special header.
"x-lpm-country: <country_code>"
Example request could look like this:
curl --proxy http://127.0.0.1:24000 -H "x-lpm-country: us" http://lumtest.com/myip.json
You may also use headers for controlling state and city:
- State:
x-lpm-state: <state>
- City:
x-lpm-city: <city_name>
To override the country selected in the port, you can send the ‘x-lpm-country’ header with the chosen country code.
curl --proxy [LPM_DOMAIN]:[PORT] -H "x-lpm-country: il" "http://lumtest.com/myip.json"
Follow Redirect is a valuable feature within the Proxy Manager that enhances your control over the handling of 30X (Redirection) errors. This feature is located within the Port Settings, under the General tab. It provides you with the option to automatically send a new request when encountering a 30X error, where the destination URL is derived from the Location response header. This documentation will guide you through enabling and using this feature.
Accessing Follow Redirect:
- Open the desired port for Follow redirect activation
- Go to General Tab: Within the Port Settings, click on the “General” tab. This is where you’ll find various settings related to how your proxy handles requests and responses.
- Toggle the Follow Redirect Feature: In the General tab, you will see the “Follow Redirect” feature. It’s presented as a toggle button, allowing you to enable or disable it as needed.
How Follow Redirect Works:
- When the Follow Redirect feature is enabled, it instructs the proxy manager to automatically send a new request in response to a 30X error.
- The URL for the new request is determined based on the Location response header received in the 30X error response.
- This allows your proxy to seamlessly follow the redirection and ensure that the request is sent to the correct destination, as specified by the Location header.
Benefits of Follow Redirect:
In environments where automatic redirection is not supported or desired, the Follow Redirect feature gives you full control.
You can control your sessions using the Proxy Manager by sending x-lpm-session header.
- Add the header with any random session ID”x-lpm-session: random_session”
- When using the same session the Proxy Manager will try to connect with the same exit node (peer/IP)
- When you change the session value the Proxy Manager will connect with a different exit node (new peer/IP)
- To keep a given session alive you must send a request no more than every 60 seconds
- Note that in order to use it with HTTPS requests you will need to enable SSL Analyzing and install the certificate
Here is an example:
curl --proxy http://127.0.0.1:24000 -H "x-lpm-session: rand123" http://lumtest.com/myip
You can refresh session on your cloud Proxy Manager with the following curl request:
curl -X POST "https://pmgr-customer-<customer_id>.brd.superproxy.io:22999/api/refresh_sessions/<port>"
In Proxy Manager, we provide users with a range of options to export logs to external storage and log monitoring systems. These export options allow you to centralize and analyze your logs efficiently. In this documentation article, we will outline the available log export options and guide you on how to configure them through Proxy Manager settings.
Log Export Options:
Proxy Manager offers the following log export options:
Logz.io
Configure the Logz.io integration in Proxy Manager settings by specifying your Logz.io token, Host and other required parameters.
AWS S3:
To export logs to AWS S3, set up the S3 integration in Proxy Manager settings. You will need to specify your AWS access key, secret key, S3 bucket name, and other relevant details.
Webhook:
Configure the webhook endpoint and any required authentication details and URL in Proxy Manager settings to start exporting logs via webhook.
Datadog:
To export logs to Datadog, set up the Datadog integration in Proxy Manager settings by providing your Datadog API key and other relevant information.
Configuring Log Exports:
To configure log exports in Proxy Manager, follow these general steps:
- Access Proxy Manager Settings:
- Navigate to the settings or configuration section.
- Select Log settings option in Enable request logs
- Toggle on Use remote logs aggregator
- Choose the desired log export option (Webhook, Datadog, Logz.io, or AWS S3).
- Provide Configuration Details: For the selected export option, you will typically need to provide specific configuration details. This may include endpoint URLs, API keys, authentication credentials, and storage settings.
- Click on Test to check the configuration
- Click OK and Save changes
By following these steps, you can effectively configure Proxy Manager to export logs to your chosen external storage or monitoring systems, enhancing your ability to monitor and manage your network and applications effectively.
Error code responds can trigger an IP refresh or try with new IP using the Proxy Manager Rules with the following steps:
- Add a new rule at Proxy Manager, rules tab
- Select ‘Status code’ as the rule type
- Trigger the rule by selecting the relevant status code to scan (i.e 501, 402, 301, etc)
- Select the desired outcome such as ‘Refresh IP’ or ‘Try with new IP’
Watch video:unblock error codes
What is needed?
To be able to access the UI (dashboard) using HTTPS protocol you need to provide the Proxy Manager with an SSL certificate and private key for your domain.
The certificate and private key should be generated specifically for your domain and installed on the server. Usually it’s done through the server and domain provider
How to do it?
Run Proxy Manager along with environment variables SSL_CERT
and SSL_KEY
pointing to the according certificate files. Example command to run in the terminal:
SSL_CERT=/path/to/ca.crt SSL_KEY=/path/to/ca.key pmgr
Once it is started you can access the UI using https://your-domain.com:22999/
By enabling the --history
flag. When history mode is enabled, both request and response headers will be saved to a local database. They can be accessed under the “Proxies” section. The history option can also track HTTPS, by enabling the ‘—ssl’ flag. For additional details, see the Bright Data Proxy Manager GitHub page.
This can also be done through the Proxy Manager dashboard by abling Log request history and Enable SSL sniffing under the General settings section.
A SOCKS server is a proxy server that works for any type of network protocol on any port and establishes a connection to a server on behalf of a user, then routes traffic between the user and the server.
Why use SOCKS5 proxies with Bright Data?
When you use SOCKS5 with Bright Data, the Proxy Manager converts any requests to port 80 or port 443 to http and https requests, so you don’t have to worry about which format is accepted by your target site. With any other port, the traffic is sent as-is between the user and the host.
Guidelines to use SOCKS5:
- Open Proxy Manager
- Click a port, then ‘Edit Proxy’
- Under ‘General’ add SOCKS port number
- Go to “Performance” - Set Reverse Resolve: DNS
- Add a resolve file
- Add ‘—resolve PATH’ to the program code
- Follow the hosts file format
- List domains you are going to use and their IPs
- Add domains and IPs from the resolve file editor in the Proxy Manager ‘tools’ page
In order to allow SOCKS5 connections, you need to undergo KYC process shown here: https://brightdata.com/cp/kyc , and request approval from our compliance department. Contact your account manager if you need assistance with this procedure.
SOCKS5
protocol uses an encrypted base64 string for authentication.
Therefore, when using SOCKS5
, if you need to define a proxy IP country (-country-<COUNTRY_CODE>
), you will have to convert your basic authentication information into base64 token:
- Browse https://www.base64encode.org
- Encode
brd-customer-<customer_id>-zone-<zone_name>-country-<COUNTRY>:<zone_password>
to Base64 format token - Use the “Basic authorization token” header you generated on the
SOCKS5
request that you send the Proxy Manager port:
curl -v "http://lumtest.com/myip.json" --socks5 127.0.0.1:24000 -H "Proxy-Authorization: Basic <Basic authorization token>"
Using the Proxy Manager offers advanced features that are not readily available in the API. Instead of having to manually code mechanisms for tasks like keeping an IP as long as possible or rotating your IP after each request, you can simply click a button in the Proxy Manager.
Guidelines to to switch from API to Proxy Manager:
- Install the Proxy Manager here
- Change the code to send HTTP requests directly to the specified port (for example, 127.0.0.1:24000) instead of to brd.superproxy.io:
- Configure the settings for your custom proxies and Zones through the Proxy Manager dashboard. You do not need to send the user parameter (brd-customer-customer_name-zone-zone_name…) alongside your requests, as all the needed data is wrapped within the manual proxy configuration.
Including all headers and cookie behavior. See bash example, using Bright Data Proxy Manager:
curl -v "http://lumtest.com/myip.json" -H 'pragma: no-cache' -H 'accept-encoding: gzip, deflate, br' -H 'accept-language: en-US,en;q=0.8' -H 'upgrade-insecure-requests: 1' -H 'user-agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.100 Safari/537.36' -H 'accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp, image/apng,\*/\*;q=0.8' -H 'cache-control: no-cache' -H 'cookie: bcookie="v=somekindofcookiexxx";' --proxy http://127.0.0.1:PORT_NUM
When using Web Unlocker API attaching headers is disabled by default, please contact support in order to approve headers attachment.
Sign in as 'root' to the remote server (running Ubuntu)
Create a service
Create a new service file in:
/etc/systemd/system/pmgr.service
[Unit]
Description=Proxy Manager
Wants=network-online.target
After=network-online.target
[Service]
Type=simple
Restart=always
RestartSec=5
Environment=NODE_ENV=production
ExecStart=/usr/bin/pmgr
User=root
StandardOutput=null
StandardError=null
[Install]
WantedBy=multi-user.target
Reload service files
systemctl daemon-reload
Start Proxy Manager service
systemctl start pmgr
Check status:
systemctl status pmgr.service
Done!
You have completed setting up Proxy Manager as a service. You can now control your new service:
service pmgr [stop|start|restart]
Enabling ‘Request details’ under ‘General settings’ will add the response headers below, and will allow you to get a wider, more specified view of your request. This feature has the same functionality as using the -debug
flag.
x-luminati-ip-destination
- IP of the targeted hostx-luminati-ip
- IP allocated to the request.x-luminati-timeline
- Time it took to complete
- This feature is turned off by default on the cloud proxy manager, if needed, make sure you enable it.
- Enabling ‘Request details’ is necessary in order to implement the action ‘Ban IP’ within a rule.
Viewing these headers can be done with one (or more) of the following ways
Sending your request in verbose mode by using the -v
flag
- Go to “General” tab
- Select “On” from “SSL analyzing”
- Go to “Rules” tab
- Select “URL” from “Rule type” drop-down list
- Choose any file type to apply regex expression
- Select “Null response” from “Action type” drop-down list
In the following example below the Proxy Manager will return a null response (0kb and still status code 200) for all requests that end with any of the file type endings .jpg|.png|.gif etc.
Use this option when you want to reduce the amount of data you wish to get in your response.
If the number of requests you rotate through a single IP is higher than what target websites allow, the website you target will identify your IP and block or mislead you with false information. It means that your information collecting can be much slower than what you’re used to.
What can I do about it?
Assuming you’re running 10 million requests, 1 request per second per IP with 1000 data center IPs, your routine can take about 3 hours. With 10,000,000 residential IPs, your routine can potentially take 1 second.
Guidelines to rotate multiple parallel sessions through Bright Data’s residential network:
- Open Proxy Manager
- Go to the ‘Overview’ menu
- Click the port of your residential zone
- Edit in the port settings ‘preset’ to ‘Rotating (IPs)’
- Route your requests to
127.0.0.1:<portnum>
where theportnum
is the port of the residential zone
Getting cloaked means that you’re getting misleading information from the website you are scraping.
Example: If you are collecting comparative competitive information to feed your automatic pricing algorithms, the target website can return artificially lower prices to your requests, to skew your pricing and profits.
What can I do about it?
When using traditional proxy networks (data center based IPs), your target websites may identify your activity quite easily and may cloak your requests. Therefore, the only way to ensure you’re not getting cloaked is to rotate your requests through residential IPs.
Guidelines for rotating requests through millions of residential IPs:
- Open Proxy Manager
- Go to the ‘Overview’ tab
- Click the port of your residential zone
- Edit in the port settings ‘preset’ to ‘Rotating (IPs)’
- Route your requests to
127.0.0.1:<portnum>
where theportnum
is the port of the residential zone
Choose “Long Single Session” on the port settings drop-down, and it will automatically ping the IP to keep the session alive:
Using Remote DNS gives you a DNS resolve server similar to that of the Proxy peer (the origin of the Proxy’s IP). This makes your request look more credible as the resolve server is usually located geographically close to the IP, whereas without using Remote DNS the resolve server is one of Bright Data’s Super-Proxies which may be located in another country. To use Remote DNS:
Go to Edit Port > IP control > set “DNS Lookup” to “Remote - resolved by peer”
When you don’t want to overload one Proxy Manager with too many requests you can create several instances of the Proxy manager on different servers.
The best way to do so is by following the next steps:
- Install the Proxy Manager locally and set all of the ports as needed
- Save the config file
- Turn on Sync configuration so all the changes will be kept in sync on all the machines automatically
- Install the Proxy Manager on the servers you want to use
- Import the config file to the proxy_manager directory in the servers
Split your traffic between the servers
request 1 -> {FIRST SERVER IP}:24000
request 2 -> {SECOND SERVER IP}:24000
Using the Proxy Manager with this method will make sure you are not overloading one Proxy Manager instance and it will help you keep the same configuration across all instances.
This means you can send requests from same port with the same country at the same time on each instance.
If you’re having troubles setting up this load-balancing yourself - you could use our Clouds that have load-balancing feature implemented. You’ll only need to use 1 UI and control all instances with shared configuration, and then target same URL, we will take the whole load-balancing process ourselves.
If you fail to login to your Proxy Manager(PM), please do the following:
- Make sure that the computer that runs PM is not using a VPN.
Mind that using a VPN while running PM might cause login problems, and also slow down the connection to the proxies - Close PM (the terminal’s black screen where PM is running)
- Delete cookies on your browser
- Open PM again (it takes about 1-2 minutes for PM to load)
- Try to log in on the same method you did before (by using Google, or by using your registered mailbox and password)
Alternatively, you may switch the hosting of Proxy Manager to our Cloud. We will take care of hosting and even load-balancing between several instances of Proxy Managers.
P.S. After PM loads, the default browser should open automatically on PM’s login page. If it does not, open your browser, browse 127.0.0.1:22999, and then try to log in.
If you cannot log in to Proxy Manager, or If Proxy Manager cannot connect to Super Proxy (i.e. port status is not OK), check the following:
- Make sure that VPN is not turned on
- Make sure that there is no anti-virus or any other security software (such as 360, Norton, etc.) blocking traffic sent from Proxy Manager
- Make sure that the firewall (OS / server / any other security software’s firewall) allows TCP traffic through ports 22000-25000
- If the proxy manager software is installed on macOS/ Linux server - Verify that:
- Node.js version is between 12.18.3 and 14.18.1
- NPM version is between 6.14.6 and 8.1.3
- If versions of NPM and Nodejs are not the one we’re supporting - please remove them and install the versions that we specified. More information regarding Linux/Mac installation can be found at our GitHub page
When Using the Data center/ISP or gIPs products, the error code 400
can appear in case the IPs under your zone has been refreshed, removed, or simply changed due to system updates
This error typically arises after your BrightData account has been recently suspended. An automatic suspension occurs if your account balance becomes negative. If the suspension extends beyond 48 hours, the static allocated IPs will be released from your account. Upon reactivation, the reallocated IPs may differ from the original ones, thus if the previously allocated IPs are still being targeted - this error is thrown.
Whenever this error appear, you should go to your Bright Data Zones page, download the new list of IPs relevant to this zone.
Make sure you also update the list of IPs in case you are using the proxy manager tool with prefix of IP port setup
Example:
curl --v "http://lumtest.com/myip.json" --proxy brd.superproxy.io:33335 --proxy-user brd-customer-<customer_id>-zone-<zone_name>-ip-1.1.1.1:<zone_password>
With Bright Data you can specify the geolocation and other parameters of the IPs you use for sending traffic. In Proxy Manager it’s especially easy because it take only a few clicks.
Depending on the zone you use you can request IPs only from a specific country (if you use Residential or Datacenter network) or additionally specific carrier (if you use Mobile network).
How to set targeting in Proxy Manager?
To get IPs from a specific location, follow these steps:
- Click on the proxy port that you want to use location-specific IPs
- Go to Targeting tab
- Select country, state, city for choosing a peer in a specific geolocation
- Select ASN or carrier name (only for mobile peers)
Was this page helpful?