Welcome!

Open Source Cloud Authors: Elizabeth White, Yeshim Deniz, Charles Araujo, Liz McMillan, Pat Romanski

Related Topics: Java IoT, Industrial IoT, Microservices Expo, Open Source Cloud, @CloudExpo, Apache

Java IoT: Article

Tracing Black Boxes II: Monitoring Solr

Providing insight into Apache Solr instances by correlating individual traces with JMX metrics

Your site is indexed on Google, but that doesn't mean you're done with search. Content-rich websites provide native search functionality to keep users engaged, maintain visual consistency, and provide content-aware filtering. But it's very hard to implement an effective, scalable search system, which is why Apache Solr is just about the most popular ‘black box' in web application infrastructure. This Lucene-backed search appliance has seen wide adoption due to its performance, reliability, and ease of deployment. In fact, it's become so widely used that many Solr deployments are managed by people who have no other exposure to running Java applications. Documents go in, indexed RESTful search comes out - that is, until something breaks.

TraceView can provide insight into Apache Solr instances by correlating individual traces with JMX metrics, such as the rate of requests over the past 5 minutes. Even at a very low overall volume, an increased traffic rate is already increasing request latency.

TraceView can provide insight into Apache Solr instances by correlating individual traces with JMX metrics, such as the rate of requests over the past 5 minutes. Even at a very low overall volume, an increased traffic rate is already increasing request latency.

Unlike most web application front-ends, Solr is a complex, stateful application that contains persistent objects, runs background indexing processes, and maintains multiple tiers of caches. There are a lot of ways to deploy and configure Solr, and that means there are a lot of ways to make mistakes. But even when you have everything up and running, there's always the lingering question of whether you could be getting more out of your Solr instances (or reducing the number of them!).

One of the best ways to get insight into Solr's internal abstractions - such as cores, handlers, and components - is to monitor them directly via JMX. I've previously written about using JMX metrics to keep tabs on JVM memory internals, but JMX is a common API for collecting data from your Java applications and any application can make use of it. Because of this it's been widely adopted in the Java ecosystem to centralize the provision of application-specific performance data.

Solr provides JMX metrics on a variety of internals, such as queryResultCache.

 

Solr provides JMX metrics on a variety of internals, such as queryResultCache.

 

Solr exposes hundreds of JMX metrics across dozens of categories, and efficient use of them can help you delve into Solr performance in a variety of ways. Some metrics are better for providing a high-level view of Solr's overall workflow. The queryResultCachecategory, pictured above, provides a snapshot of how often your data was successfully cached, as well as how often cache entries had to be evicted due to insufficient space. Other metric categories are more granular and provide detail at the level of classes, or even objects. An update request will be routed to a different handler depending on whether the data was provided in XML, CSV, or JSON; each of these update handlers exposes metrics independently, like how long it has been running and the number of errors.

JMX metrics can even provide insight into advanced Solr use cases, like modifying result scoring to permit n-dimensional spatial searches or customizing results based on user data stored in Redis. Even without adding custom JMX metrics, Solr will report enough data to allow you to separately track the effectiveness of these custom searches relative to more traditional queries.

Let's look at a practical example. You just got paged because half of your distributed Solr cluster lost connectivity in a widespread EC2 outage. It looks like it might last a while, so you decide to add additional capacity in one of the functioning availability zones. Rather than spending time re-indexing your content, you decide to replicate your existing Solr data to the new servers. Using the high-level metrics provided byReplicationHandler, you determine that replication is proceeding smoothly. Halfway through your second replication, though, you realize that the first replicated server is taking five times as long as your original servers to respond to the same user queries, even though it's running on the same hardware. Checking out the cache metrics for a specific search handler, it looks like the hit ratios on its caches are abysmal - but wait, what's actually in those caches? After checking the metrics for that node's active Searcher instance, you realize you didn't set up Solr to warm the cache - it was starting off empty! Now you know to make a quick configuration change next time you spin up an instance so that the first users routed to it will have acceptable performance.

So, that sounds awesome - but how do you do it? The easiest approach is to view Solr's JMX statistics through its web interface (in Solr 3.x,
it's at /solr/admin/stats.jsp, while in Solr 4.x it's available at a collection-based URL like /solr/#/collection1/plugins/). However, web access won't be an option for most deployments. Alternately, you could use remote jconsole, but that requires either a complex remote configuration that's a tremendous hassle to set up or the glacially slow option of SSH X11 forwarding (e.g., ssh -X solr jconsole).

In practice, those approaches all suck. Solr is stunningly verbose: it exposes hundreds of JMX metrics out of the box, and that number expands quickly as you add additional handlers and components. Purpose-built JMX monitoring tools like jconsole are great for browsing the available metrics to see what's available, but they're horrible for pulling out the ones you want in a hurry. They also allow ‘write' operations like initiating garbage collection or clearing caches - definitely not something you want to give out to every developer!

TraceView automatically monitors the JMX metrics of every node involved in this distributed Solr Cloud trace.

 

TraceView automatically monitors the JMX metrics of every node involved in this distributed Solr Cloud trace.

On a day to day basis, it's more common to read JMX metrics via automated, ‘read-only' monitoring tools like NagiosGanglia, or AppNeta TraceView. These tools not only present a number of metrics at once, but they also generally let you filter down to a meaningful subset of the hundreds of lines exposed by Solr. On the other hand, "health check"-style metrics aren't necessarily the only way to look the problem. Each request has a number of metrics it can generate, and bringing together these data sources in one application has some real advantages. Looking at an individual request can tell you exactly what went wrong, it's often the context of JMX data that says why. Examining the concurrent host activity can disambiguate between whether a pause was due to a garbage collection event in the JVM or an overloaded document cache in Solr forcing additional disk access.

Next time, we'll talk about how TraceView captures these request-based metrics directly from the Solr internals. In the meantime, if you've got a Solr installation, sign up for your free account, put in on that server, and take a look inside that black box!

More Stories By James Meickle

James started as a hobbyist web developer, even though his academic background is in social psychology and political science. Lately his interests as a professional Drupal developer have migrated towards performance, security, and automation. His favorite languages is Python, his favorite editor is Sublime, and his favorite game is Dwarf Fortress.

@ThingsExpo Stories
To Really Work for Enterprises, MultiCloud Adoption Requires Far Better and Inclusive Cloud Monitoring and Cost Management … But How? Overwhelmingly, even as enterprises have adopted cloud computing and are expanding to multi-cloud computing, IT leaders remain concerned about how to monitor, manage and control costs across hybrid and multi-cloud deployments. It’s clear that traditional IT monitoring and management approaches, designed after all for on-premises data centers, are falling short in ...
Organizations planning enterprise data center consolidation and modernization projects are faced with a challenging, costly reality. Requirements to deploy modern, cloud-native applications simultaneously with traditional client/server applications are almost impossible to achieve with hardware-centric enterprise infrastructure. Compute and network infrastructure are fast moving down a software-defined path, but storage has been a laggard. Until now.
DXWorldEXPO LLC announced today that the upcoming DXWorldEXPO | CloudEXPO New York event will feature 10 companies from Poland to participate at the "Poland Digital Transformation Pavilion" on November 12-13, 2018.
Digital Transformation is much more than a buzzword. The radical shift to digital mechanisms for almost every process is evident across all industries and verticals. This is often especially true in financial services, where the legacy environment is many times unable to keep up with the rapidly shifting demands of the consumer. The constant pressure to provide complete, omnichannel delivery of customer-facing solutions to meet both regulatory and customer demands is putting enormous pressure on...
The best way to leverage your CloudEXPO | DXWorldEXPO presence as a sponsor and exhibitor is to plan your news announcements around our events. The press covering CloudEXPO | DXWorldEXPO will have access to these releases and will amplify your news announcements. More than two dozen Cloud companies either set deals at our shows or have announced their mergers and acquisitions at CloudEXPO. Product announcements during our show provide your company with the most reach through our targeted audienc...
In an era of historic innovation fueled by unprecedented access to data and technology, the low cost and risk of entering new markets has leveled the playing field for business. Today, any ambitious innovator can easily introduce a new application or product that can reinvent business models and transform the client experience. In their Day 2 Keynote at 19th Cloud Expo, Mercer Rowe, IBM Vice President of Strategic Alliances, and Raejeanne Skillern, Intel Vice President of Data Center Group and ...
More and more brands have jumped on the IoT bandwagon. We have an excess of wearables – activity trackers, smartwatches, smart glasses and sneakers, and more that track seemingly endless datapoints. However, most consumers have no idea what “IoT” means. Creating more wearables that track data shouldn't be the aim of brands; delivering meaningful, tangible relevance to their users should be. We're in a period in which the IoT pendulum is still swinging. Initially, it swung toward "smart for smart...
@DevOpsSummit at Cloud Expo, taking place November 12-13 in New York City, NY, is co-located with 22nd international CloudEXPO | first international DXWorldEXPO and will feature technical sessions from a rock star conference faculty and the leading industry players in the world.
DXWorldEXPO LLC announced today that All in Mobile, a mobile app development company from Poland, will exhibit at the 22nd International CloudEXPO | DXWorldEXPO. All In Mobile is a mobile app development company from Poland. Since 2014, they maintain passion for developing mobile applications for enterprises and startups worldwide.
In his keynote at 19th Cloud Expo, Sheng Liang, co-founder and CEO of Rancher Labs, discussed the technological advances and new business opportunities created by the rapid adoption of containers. With the success of Amazon Web Services (AWS) and various open source technologies used to build private clouds, cloud computing has become an essential component of IT strategy. However, users continue to face challenges in implementing clouds, as older technologies evolve and newer ones like Docker c...
DXWorldEXPO LLC announced today that ICC-USA, a computer systems integrator and server manufacturing company focused on developing products and product appliances, will exhibit at the 22nd International CloudEXPO | DXWorldEXPO. DXWordEXPO New York 2018, colocated with CloudEXPO New York 2018 will be held November 11-13, 2018, in New York City. ICC is a computer systems integrator and server manufacturing company focused on developing products and product appliances to meet a wide range of ...
Coca-Cola’s Google powered digital signage system lays the groundwork for a more valuable connection between Coke and its customers. Digital signs pair software with high-resolution displays so that a message can be changed instantly based on what the operator wants to communicate or sell. In their Day 3 Keynote at 21st Cloud Expo, Greg Chambers, Global Group Director, Digital Innovation, Coca-Cola, and Vidya Nagarajan, a Senior Product Manager at Google, discussed how from store operations and ...
We are seeing a major migration of enterprises applications to the cloud. As cloud and business use of real time applications accelerate, legacy networks are no longer able to architecturally support cloud adoption and deliver the performance and security required by highly distributed enterprises. These outdated solutions have become more costly and complicated to implement, install, manage, and maintain.SD-WAN offers unlimited capabilities for accessing the benefits of the cloud and Internet. ...
Headquartered in Plainsboro, NJ, Synametrics Technologies has provided IT professionals and computer systems developers since 1997. Based on the success of their initial product offerings (WinSQL and DeltaCopy), the company continues to create and hone innovative products that help its customers get more from their computer applications, databases and infrastructure. To date, over one million users around the world have chosen Synametrics solutions to help power their accelerated business or per...
Dion Hinchcliffe is an internationally recognized digital expert, bestselling book author, frequent keynote speaker, analyst, futurist, and transformation expert based in Washington, DC. He is currently Chief Strategy Officer at the industry-leading digital strategy and online community solutions firm, 7Summits.
Founded in 2000, Chetu Inc. is a global provider of customized software development solutions and IT staff augmentation services for software technology providers. By providing clients with unparalleled niche technology expertise and industry experience, Chetu has become the premiere long-term, back-end software development partner for start-ups, SMBs, and Fortune 500 companies. Chetu is headquartered in Plantation, Florida, with thirteen offices throughout the U.S. and abroad.
Bill Schmarzo, author of "Big Data: Understanding How Data Powers Big Business" and "Big Data MBA: Driving Business Strategies with Data Science," is responsible for setting the strategy and defining the Big Data service offerings and capabilities for EMC Global Services Big Data Practice. As the CTO for the Big Data Practice, he is responsible for working with organizations to help them identify where and how to start their big data journeys. He's written several white papers, is an avid blogge...
Bill Schmarzo, author of "Big Data: Understanding How Data Powers Big Business" and "Big Data MBA: Driving Business Strategies with Data Science," is responsible for setting the strategy and defining the Big Data service offerings and capabilities for EMC Global Services Big Data Practice. As the CTO for the Big Data Practice, he is responsible for working with organizations to help them identify where and how to start their big data journeys. He's written several white papers, is an avid blogge...
Charles Araujo is an industry analyst, internationally recognized authority on the Digital Enterprise and author of The Quantum Age of IT: Why Everything You Know About IT is About to Change. As Principal Analyst with Intellyx, he writes, speaks and advises organizations on how to navigate through this time of disruption. He is also the founder of The Institute for Digital Transformation and a sought after keynote speaker. He has been a regular contributor to both InformationWeek and CIO Insight...
"IBM is really all in on blockchain. We take a look at sort of the history of blockchain ledger technologies. It started out with bitcoin, Ethereum, and IBM evaluated these particular blockchain technologies and found they were anonymous and permissionless and that many companies were looking for permissioned blockchain," stated René Bostic, Technical VP of the IBM Cloud Unit in North America, in this SYS-CON.tv interview at 21st Cloud Expo, held Oct 31 – Nov 2, 2017, at the Santa Clara Conventi...