To some, the database is a low-level infrastructure component of a much larger application -- something that only developers, DBAs and operations staff need to care or worry about.
However, in the digital economy, data is the raw currency. How an organization stores, manages, analyzes and uses data has a direct impact on its success -- and its costs. Its choice of database affects how quickly it can deliver new applications to market, support business growth and improve customer experience. Consider these examples:
- After trying for eight years to build a single view of their customer, one of the world’s leading insurance companies changed database and delivered the project in just three months
- A leading telecommunications provider adopted a new database technology and were able to accelerate time to market by 4x, reduce engineering costs by 50% and improve customer experience by 10x
- A Tier 1 investment bank rebuilt its globally-distributed reference data platform on a new database technology, enabling it to save an estimated $40M over five years
- Singles can now find their ideal partner 95% faster after one of the world’s leading relationship providers switched data and machine learning to a new platform
Why is database selection becoming so critical? Because the requirements of modern applications and the demands of sophisticated, data-savvy users are changing. Data is being generated at much faster rates than ever before and can yield insights never previously possible. The data no longer fits neatly into structured rows and columns. Windows of market opportunity are getting smaller. Underlying infrastructure is being commoditized, with powerful systems available for just pennies per hour.
The database chosen by a project team can be the enabler -- or the blocker -- to success. All of the assumptions that have dictated database selection over the past 30 years are being revisited as a result of the factors discussed above.
To learn more about the challenges some of the world’s largest and most innovative companies faced, and how their selection of database enabled them to deliver applications and outcomes that were never previously possible, download our new whitepaper
5 Reasons to Send Your Team to MongoDB World
MongoDB World is coming soon. This is the largest MongoDB Event ever, with over 80 training and conference sessions to give the community insight into the possibilities with MongoDB. Here's why your team needs to be there: Real-World technical insight into MongoDB Development and Management You can learn MongoDB online through a number of resources, but there's nothing like learning from experience. At MongoDB World, you'll hear from startups like Stripe to large enterprises like Cisco and TicketMaster and government agencies like the Department of Veterans affairs and the UK Government digital services about how they develop, optimize and manage their MongoDB installations. Your team, regardless of their MongoDB expertise, will learn from the insights and trade offs of companies in finance , retail , telecommunications and more. Learn MongoDB from Start to Finish Whether your team is building new applications with MongoDB or optimizing existing work with the database, they will walk away with critical insight into the strategies for building and deploying applications in our Prototype to Production, or P2P , track. Led by MongoDB engineers, the P2P track will walk you through 5 distinct applications and give you insight into how to leverage MongoDB's unique feature set to solve critical problems in application development. Each application will have three consecutive sessions dedicated to different facets of the application, including schema design, key features, data aggregation options like Hadoop , hardware considerations and deployment strategies. From application developers to DBAs, everyone will walk away better prepared to build applications with MongoDB. Get Certified On site certification for developers and DBAs will be available at MongoDB World. The exam is offered every online every six weeks. At MongoDB World, we will offer in-person proctored exams for attendees to make the most out of their time at MongoDB World. Network with the Fastest Growing community in Big Data Conferences are only as valuable as the attendees in the hallway track. The largest MongoDB event ever will bring together global leaders from the fastest-growing community in big data . Your team will have the opportunity to network with core MongoDB engineers, core community leaders including the MongoDB Masters , MUG organizers and other experts in the community. Attendees will network at special interest group tables, Birds of a Feather sessions, in the hallway track and at the MongoDB after party at the Intrepid Sea, Air & Space Museum. There's no other place where your team can share knowledge and practical experience with their peers who have faced similar technical challenges. As Charity Majors of Parse said, "My favorite part about MongoDB Days is getting to meet all the other people who are running MongoDB at scale ... I came back from the last MongoDB conference with all kinds of ideas for scaling and tuning my systems." See the future of MongoDB While there is always the opportunity for your developers to talk to a core MongoDB server engineer on IRC, there's nothing quite like discussing the future of MongoDB face-to-face with your peers. At MongoDB World, the core MongoDB development team, led by CTO and Co-founder, Eliot Horowitz, will discuss future project development with the community. Your team's insight into the future roadmap will equip them to make better decisions about your deployment and architecture. Give your team access to this insight and the opportunity to lobby for their top priority changes and design directions directly with the team that builds the database. Thinking about sending your team to New York City for MongoDB World ? Don't delay! Early bird prices for MongoDB world end on May 23. Save over $300 on tickets and register today !
How to Get Started with MongoDB Atlas and Confluent Cloud
Every year more and more applications are leveraging the public cloud and reaping the benefits of elastic scale and rapid provisioning. Forward-thinking companies such as MongoDB and Confluent have embraced this trend, building cloud-based solutions such as MongoDB Atlas and Confluent Cloud that work across all three major cloud providers. Companies across many industries have been leveraging Confluent and MongoDB to drive their businesses forward for years. From insurance providers gaining a customer-360 view for a personalized experience to global retail chains optimizing logistics with a real-time supply chain application, the connected technologies have made it easier to build applications with event-driven data requirements. The latest iteration of this technology partnership simplifies getting started with a cloud-first approach, ultimately improving developer’s productivity when building modern cloud-based applications with data in motion. Today, the MongoDB Atlas source and sink connectors are generally available within Confluent Cloud. With Confluent’s cloud-native service for Apache Kafka® and these fully managed connectors, setup of your MongoDB Atlas integration is simple. There is no need to install Kafka Connect or the MongoDB Connector for Apache Kafka, or to worry about scaling your deployment. All the infrastructure provisioning and management is taken care of for you, enabling you to focus on what brings you the most value — developing and releasing your applications rapidly. Let’s walk through a simple example of taking data from a MongoDB cluster in Virginia and writing it into a MongoDB cluster in Ireland. We will use a python application to write fictitious data into our source cluster. Step 1: Set up Confluent Cloud First, if you’ve not done so already, sign up for a free trial of Confluent Cloud . You can then use the Quick Start for Apache Kafka using Confluent Cloud tutorial to create a new Kafka cluster. Once the cluster is created, you need to enable egress IPs and copy the list of IP addresses. This list of IPs will be used as an IP Allow list in MongoDB Atlas. To locate this list, select “Custer Settings” and then the “Networking” tab. Keep this tab open for future reference: you will need to copy these IP addresses into the Atlas cluster in Step 2. Step 2: Set Up the Source MongoDB Atlas Cluster For a detailed guide on creating your own MongoDB Atlas cluster, see the Getting Started with Atlas tutorial. For the purposes of this article, we have created an M10 MongoDB Atlas cluster using the AWS cloud in the us-east-1 (Virginia) data center to be used as the source, and an M10 MongoDB Atlas cluster using the AWS cloud in the eu-west-1 (Ireland) data center to be used as the sink. Once your clusters are created, you will need to configure two settings in order to make a connection: database access and network access. Network Access You have two options for allowing secure network access from Confluent Cloud to MongoDB Atlas: You can use AWS PrivateLink, or you can secure the connection by allowing only specific IP connections from Confluent Cloud to your Atlas cluster. In this article, we cover securing via IPs. For information on setting up using PrivateLink, read the article Using the Fully Managed MongoDB Atlas Connector in a Secure Environment . To accept external connections in MongoDB Atlas via specific IP addresses, launch the “IP Access List” entry dialog under the Network Access menu. Here you add all the IP addresses that were listed in Confluent Cloud from Step 1. Once all the egress IPs from Confluent Cloud are added, you can configure the user account that will be used to connect from Confluent Cloud to MongoDB Atlas. Configure user authentication in the Database Access menu. Database Access You can authenticate to MongoDB Atlas using username/password, certificates, or AWS identity and access management (IAM) authentication methods. To create a username and password that will be used for connection from Confluent Cloud, select the “+ Add new Database User” option from the Database Access menu. Provide a username and password and make a note of this credential, because you will need it in Step 3 and Step 4 when you configure the MongoDB Atlas source and sink connectors in Confluent Cloud. Note: In this article we are creating one credential and using it for both the MongoDB Atlas source and MongoDB sink connectors. This is because both of the clusters used in this article are from the same Atlas project. Now that the Atlas cluster is created, the Confluent Cloud egress IPs are added to the MongoDB Atlas Allow list, and the database access credentials are defined, you are ready to configure the MongoDB Atlas source and MongoDB Atlas sink connectors in Confluent Cloud. Step 3: Configure the Atlas Source Now that you have two clusters up and running, you can configure the MongoDB Atlas connectors in Confluent Cloud. To do this, select “Connectors” from the menu, and type “MongoDB Atlas” in the Filters textbox. Note: When configuring MongoDB Atlas source And MongoDB Atlas sink, you will need the connection host name of your Atlas clusters. You can obtain this host name from the MongoDB connection string. An easy way to do this is by clicking on the "Connect" button for your cluster. This will launch the Connect dialog. You can choose any of the Connect options. For purposes of illustration, if you click on “Connect using MongoDB Compass.” you will see the following: The highlighted part in the above figure is the connection hostname you will use when configuring the source and sink connectors in Confluent Cloud. Configuring the MongoDB Atlas Source Connector Selecting “MongoDbAtlasSource” from the list of Confluent Cloud connectors presents you with several configuration options. The “Kafka Cluster credentials” choice is an API-based authentication that the connector will use for authentication with the Kafka broker. You can generate a new API key and secret by using the hyperlink. Recall that the connection host is obtained from the MongoDB connection string. Details on how to find this are described at the beginning of this section. The “Copy existing data” choice tells the connector upon initial startup to copy all the existing data in the source collection into the desired topic. Any changes to the data that occur during the copy process are applied once the copy is completed. By default, messages from the MongoDB source are sent to the Kafka topic as strings. The connector supports outputting messages in formats such as JSON and AVRO. Recall that the MongoDB source connector reads change stream data as events. Change stream event metadata is wrapped in the message sent to the Kafka topic. If you want just the message contents, you can set the “Publish full document only” output message to true. Note: For source connectors, the number of tasks will always be “1”: otherwise you will run the risk of duplicate data being written to the topic, because multiple workers would effectively be reading from the same change stream event stream. To scale the source, you could create multiple source connectors and define a pipeline that looks at only a portion of the collection. Currently this capability for defining a pipeline is not yet available in Confluent Cloud. Step 4: Generate Test Data At this point, you could run your python data generator application and start inserting data into the Stocks.StockData collection at your source. This will cause the connector to automatically create the topic “demo.Stocks.StockData.” To use the generator, git-clone the stockgenmongo folder in the above-referenced repository and launch the data generation as follows: python stockgen.py -c "< >" Where the MongoDB connection URL is the full connection string obtained from the Atlas source cluster. An example connection string is as follows: mongodb+srv://kafkauser:email@example.com Note: You might need to pip-install pymongo and dnspython first. If you do not wish to use this data generator, you will need to create the Kafka topic first before configuring the MongoDB Atlas sink. You can do this by using the Add a Topic dialog in the Topics tab of the Confluent Cloud administration portal. Step 5: Configuring the MongoDB Atlas Sink Selecting “MongoDB Atlas Sink” from the list of Confluent Cloud connectors will present you with several configuration options. After you pick the topic to source data from Kafka, you will be presented with additional configuration options. Because you chose to write your data in the source by using JSON, you need to select “JSON” in the input message format. The Kafka API key is an API key and secret used for connector authentication with Confluent Cloud. Recall that you obtain the connection host from the MongoDB connection string. Details on how to find this are described previously at the beginning of Step 3. The “Connection details” section allows you to define behavior such as creating a new document for every topic message or updating an existing document based upon a value in the message. These behaviors are known as document ID and write model strategies. For more information, check out the MongoDB Connector for Apache Kafka sink documentation . If order of the data in the sink collection is not important, you could spin up multiple tasks to gain an increase in write performance. Step 6: Verify Your Data Arrived at the Sink You can verify the data has arrived at the sink via the Atlas web interface. Navigate to the collection data via the Collections button. Now that your data is in Atlas, you can leverage many of the Atlas platform capabilities such as Atlas Search, Atlas Online Archive for easy data movement to low-cost storage, and MongoDB Charts for point-and-click data visualization. Here is a chart created in about one minute using the data generated from the sink cluster. Summary Apache Kafka and MongoDB help power many strategic business use cases, such as modernizing legacy monolithic systems, single views, batch processing, and event-driven architectures, to name a few. Today, Confluent and MongoDB Cloud and MongoDB Atlas provide fully managed solutions that enable you to focus on the business problem you are trying to solve versus spinning your tires in infrastructure configuration and maintenance. Register for our joint webinar to learn more!