Destinations Overview
Destinations are the business tools or apps that Segment forwards your data to. Adding Destinations allow you to act on your data and learn more about your customers in real time.
Destinations Catalog
If you want to explore the destinations compatible with Segment, check out the Destinations catalog. Select an item from the catalog to learn more about it. The documentation for each destination explains how the Segment Tracking API methods are implemented for that destination.
Sources vs Destinations
Segment has Sources and Destinations. Sources send data into Segment, while Destinations receive data from Segment.
Destination connection types
Segment has three destination connection types:
Event streams destinations
Event streams destinations are all destinations that aren’t storage or Reverse ETL destinations. Adding these destinations allow you to act on your data and learn more about your customers in real time. These include Destination Actions.
Storage destinations
Storage destinations enable you to store your raw Segment data. This enables data analysts and data scientists to work with the raw data to derive deeper and more customized insights to support your organization. Learn more from the storage overview page.
Reverse ETL destinations
Reverse ETL destinations are the business tools or apps you use that Segment syncs the data from your warehouse to.
If your destination is not listed in the Reverse ETL catalog, use the Segment Connections destination to send data from your Reverse ETL warehouse to other destinations listed in the catalog. The Segment Connections destination enables you to mold data extracted from your warehouse in Segment Spec API calls that are then processed by Segment’s HTTP Tracking API. The Segment HTTP Tracking API lets you record analytics data. The requests hit Segment’s servers, and then Segment routes your data to any destination you want. Get started with the Segment Connections destination.
Method compatibility
Not all destinations can accept data from specific method types. To know if a destination can accept data from specific method types, look for the Quick Info box at the top of the destination’s documentation page, or check out the Destinations Methods comparison chart.
Source compatibility
Many destinations can accept data from all types of sources, but some are only compatible with specific source types (for example, web only, or server only). To find out which source types a specific destination can accept data from, check the documentation for that destination in the Quick info box, or in the Supported Sources and Connection Modes section.
Destination Actions
In June 2021, Segment released a new form of destinations called Destinations Actions. These destinations allow users to create subscriptions: sets of conditions in which data is sent to the destinations and data mappings, to format that data for the destination tool. Segment watches for data that matches the conditions you create (triggers) for the subscription, and when the conditions are met, uses an explicit mapping to transform the incoming data to an output format that your destination can use.
Connection modes
Segment’s web source (Analytics.js), and native client-side libraries (iOS, Android, React-native) allow you to choose how you send data to Segment from your website or app. There are two ways to send data:
-
Cloud-mode: The sources send data directly to the Segment servers, which then translate it for each connected downstream destination, and send it on. Translation is done on the Segment servers, keeping your page size, method count, and load time small.
Healthcare and Life Sciences (HLS) customers can encrypt data flowing into their destinations
HLS customers with a HIPAA eligible workspace can encrypt data in fields marked as Yellow in the Privacy Portal before they flow into an event stream, cloud-mode destination.
To learn more about data encryption, see the HIPAA Eligible Segment documentation -
Device-mode: You include additional code on your website or mobile app which allows Segment to use the data you collect on the device to make calls directly to the destination tool’s API, without sending it to the Segment servers first. (You still send your data to the Segment servers, but this occurs asynchronously.) This is also called wrapping or bundling, and it might be required when the source has to be loaded on the page to work, or loaded directly on the device to function correctly. When you use Analytics.js, you can change the device-mode destinations that a specific source sends from within the Segment web app, without touching any code.
If you use Server source libraries, they only send data directly to Segment in Cloud-mode. Server library implementations operate in the server backend, and can't load additional destination SDKs.
Choosing a connection mode
Cloud-mode destinations send data through Segment. Device-mode destinations send data in parallel to Segment. There are tradeoffs between using cloud-mode and device-mode destinations. In general, Cloud-mode is preferred because you then benefit from Segment’s system features, like retries, Replay, Warehouses, Privacy blocking, filtering, and more.
You should consider using device-mode if you use destinations which record information directly on the user’s device. These types of tools might lose functionality if they aren’t loaded directly on the device.
Take a look at the pros and cons chart of device-mode and cloud-mode destinations to determine which connection mode is best for you:
Connection Mode | Pros | Cons |
---|---|---|
Cloud-mode | * Increased site or app performance * Unaffected by ad blockers |
* May limit Destination features |
Device-mode | * Access to all features of the Destination | * Decreased site or app performance |
Website source connection modes
Segment’s website sources use device-mode by default, because so many website-based destinations require that they be loaded on the page, and because size and page performance are less of a concern than on mobile. If your website source only collects information that you can instrument yourself, then you can use cloud-mode.
For example, a web-chat destination must be loaded to connect to the service and collect metrics efficiently - you don’t expect it to route chat messages through Segment! This does mean that Segment might not receive a small amount of the destination-specific information from your users. In the chat example, if the destination is calculating idle time between messages, that data would appear in the destination’s tooling, but not necessarily in the Segment data.
Mobile source connection modes
By default, destinations configured on a mobile source send their data directly to the Segment servers, then translate it and use Cloud-mode to forward it to destinations. Cloud-mode means that Segment sends the data directly from the Segment servers, to their servers. This means you don’t need to package third-party SDKs for destinations that can accept cloud-mode data. Some primarily web-based destinations also allow cloud-mode, which can help reduce app size, and improve load time and performance. You can read more about the effects of mobile app size on downloads in Segment’s blog.
Before you turn on or opt-in for cloud-mode for a mobile source, consider if your destinations have features that require interactions on the device or require device-specific data (see the examples above). For example, if you use cloud-mode for Mixpanel, you’ll get your data on reporting and people, but won’t be able to use their features for in-app surveys or auto-tracking. These can be really valuable, but might not be a priority for your team.
How Segment determines Device-mode and Cloud-mode destinations
There are two main things Segment considers when deciding to use Device-mode or Cloud-mode, or both, for a destination partner:
Anonymous attribution methodology
Mobile attribution
The anonymous identifiers used on mobile devices are usually static, which means Segment doesn’t need to do additional resolution, and can build Cloud-mode destinations by default. Because Segment uses native advertising identifiers on mobile devices, you don’t need a full SDK on the device to reconcile or identify a user. For example, you might track users who viewed an advertisement in one app and installed another app as a result.
However, some mobile attribution tools do more advanced reconciliation based on more than the native identifier, which requires the SDK on the device to work properly. For those destinations, Segment offers device-mode, which packages the tool’s SDK with the client-side library so that you can get the entire range of tool functionality.
Web Attribution
Cross-domain identity resolution for websites requires that the attribution tool use a third-party cookie so it can track a user anonymously across domains. This is a critical component of attribution modeling. As a matter of principle, Segment only uses first-party cookies and doesn’t share cookies with partners, so Analytics.js and the data it collects aren’t enough to generate view-through attribution in ad networks.
Customers can load their libraries and pixels in the context of the browser and trigger requests to attribution providers from their device in response to Segment API calls to take advantage of advertising and attribution tools.
Client-native destination features
Many of Segment’s destinations offer client-side features beyond data collection in their SDKs and libraries, for both mobile and web. In these cases, Segment offers Device-mode SDKs so that you can collect information on the device using Segment, but still get the destination’s complete native functionality.
Some features that usually require Device-mode include: automatic A/B testing, displaying user surveys, live chat or in-app notifications, touch and hover heatmapping, and accessing rich device data such as CPU usage, network data, or raised exceptions.
How can I tell which connection modes and platforms are supported for a destination?
The first place to look is the individual destination documentation. Each one includes a matrix of supported Sources and Connection Modes. Segment provides a list of all destinations and their connection modes.
In order to override the default, check the destination settings pane in the Segment web App either for a Connection Mode toggle or instructions on bundling any additional mobile components required.
Add a destination
To add a Destination:
- Navigate to Connections.
- Click Add Destination.
- Choose the Destination you want to add and click Configure. Most users eventually add destinations for: Analytics, Advertising, Email Marketing and/or Live Chat.
- Select the Source you want to connect to your Destination.
- Click Next.
- Give you Destination a name.
- Click Save.
- Configure the settings and enable your destination on the destination settings page.
Learn more about what adding a destination entails.
Disabled destinations do not receive data
If you haven’t enabled your destination for the first time after you created it or if you actively disable a destination, Segment prevents any data from reaching the destination. Business Tier customers can request a Replay, which resends data from the time the destination was disabled to the time it was re-enabled. Replays can also send data to currently disabled destinations.
Some destinations are not compatible with Replays after a certain period of time, for example, 14 days. Check with Segment’s support team friends@segment.com to confirm that your intended destination allows historical timestamps.
Data deliverability
Segment increases deliverability to destinations using retries and replays. Retries happen automatically for all customers, while replays are available on request for Business Tier customers.
Segment’s data flow is primarily unidirectional, from Segment to integrated destinations. Segment does not inherently support a bidirectional flow where events, once delivered and processed by a destination, are sent back to Segment.
Segment also uses batching to increase deliverability to your destinations. Some destinations have batching enabled by default, and some, like Segment’s Webhook (Actions) Destination, let you opt in to batching.
Some cases of event batching might lead to observability loss
While batching does increase event deliverability, you might experience error amplification, as if the entire batch fails, all events will be marked with the same status. For example, if a batch fails due to one 429
(Rate Limit) error, it might appear in the UI that there was one 429s request failure for each item in the batch.
Retries
Retries in Segment’s client libraries
Segment’s client libraries ensure delivery of your data to the API reliably in the face of spotty connections, device failure, or network partitions in your data centers.
When you use Segment’s mobile SDK, Segment dispatches each event to a background thread where the event is then written to a queue. Later, Segment’s SDK batches together many requests in to one compressed request and sends it to Segment’s servers. Segment’s SDKs minimize battery use and bandwidth use by powering up the radio less frequently and for shorter time periods.
If the delivery of the payload is not successfully sent due to connection issues, all of your SDKs will automatically retry the request until successful receipt of the payload according to the following policies. Note that retry policies are subject to change / tuning in the future.
Platform | Initial Wait - Sleep duration before the first retry | Wait Growth - Rate of growth of the sleep duration between each retry | Max Wait - Maximum sleep duration between retries | Max Attempts - Maximum number of individual retries |
---|---|---|---|---|
C++ | 1s | None | 1s | 5 |
Clojure | 15s | Exponential | 1h | 50 |
Go | 100ms | Exponential | 10s | 10 |
Java | 15s | Exponential | 1h | 50 |
JavaScript | 1s | Exponential | 1h | 10 |
.Net | 100ms | Exponential | 6.4s | 7 |
Node.js | 100ms | Exponential | 400ms | 3 |
PHP | 100ms | Exponential | 6.4s | 7 |
Python | 1s | Exponential | 34m | 10 |
Ruby | 100ms | Exponential | 10s | 10 |
Mobile library retries
All mobile libraries handle retries by periodically attempting to flush their internal queue of events to Segment. If the flush is unsuccessful, the library waits until the next regularly-scheduled flush time to try again. The background queue of requests to Segment is bounded in size so if events are being queued faster than we can successfully flush them to Segment, some events may be dropped.
Retries between Segment and destinations
The destination endpoint APIs have fluctuations in availability due to a number of issues ranging from network failures to bugs to overload. Segment’s internal systems retry failed destination API calls for four hours with a randomized exponential backoff after each attempt. This substantially improves delivery rates.
Here’s an example destination that was only successfully accepting 93.36% of all API requests but was achieving a 99.28% final deliverability rate due to Segment’s retry functionality.
You can see the current destination endpoint API success rates and final delivery rates for Segment’s server-side destinations on Segment’s status page.
Replays
Replay is available to Business tier customers. Contact Segment to learn more.
Replays allow customers to load historical data from Segment’s S3 logs into downstream destinations which accept cloud-mode data. So, for example, if you wanted to try out a new email or analytics tool, Segment can replay your historical data into that tool. This gives you a great testing environment and prevents data lock-in when vendors try to hold data hostage.
If you submitted suppress_only
requests, Segment still retains historical events for those users, which can be replayed. If you do not want historical events replayed for suppressed users, submit suppress_and_delete
requests instead.
Batching
Segment uses stream batching for all destinations that require near-realtime data and bulk batching for some data flows in our pipeline.
Stream batching
For all destinations, except for non-realtime Engage syncs and Reverse ETL syncs, Segment processes events from your source as they arrive and then flows the data downstream to your destinations in small batches, in a process called stream batching. These batches might contain different events between retry attempts, as events in previous batches may have succeeded, failed with a permanent error, or expired. This variability reduces the workload the system processes during partial successes, allows for better per-event handling, and reduces the chance of load-related failures by using variable batch formations.
Bulk batching
Some data flows may be able to use a process called bulk batching, which supports batching for destinations that produce between several thousand and a million events at a time. Real-time workloads or using a Destination Insert Function may prevent bulk batches from being formed. Batches contain the same events between retries.
The following destinations support bulk batching:
- DV360
- Google Adwords Remarketing Lists
- Klaviyo (Actions)
- Pinterest Audiences
- Snapchat Audiences
- LiveRamp
- The Trade Desk CRM
You must manually configure bulk batches for Actions destinations
To support bulk batching for the Actions Webhook destination, you must set enable-batching: true
and batch_size: >= 1000
.
IP Allowlisting
IP Allowlisting uses a NAT gateway to route traffic from Segment’s servers to your destination through a limited range of IP addresses, which can prevent malicious actors from establishing TCP and UDP connections with your integrations.
IP Allowlisting is available for customers on Business Tier plans.
Supported destinations
Segment supports IP Allowlisting in all destinations except for the following:
Destinations that are not supported receive traffic from randomly assigned IP addresses.
Configure IP Allowlisting
To enable IP Allowlisting for your workspace:
- From your Segment workspace, navigate to Settings > Workspace settings > Destination IP settings.
- On the Destination IP settings page, click Enable IP allowlisting.
- The page displays the IP address ranges that Segment uses to route data from Segment’s internal systems to your destination. Note these ranges, as you’ll need this information to enforce IP restriction in your downstream destinations.
- Open each of your downstream tools and configure IP restriction for each destination. For more information, refer to the documentation for your downstream tool.
IP restriction might not be supported in all destinations.
This page was last modified: 02 Aug 2024
Need support?
Questions? Problems? Need more info? Contact Segment Support for assistance!