"It's a poor workman who blames his tools..."With the Internet abuzz about Google being in talks with Twitter, it seems that Ruby has become the proverbial whipping boy for Twitter's scaling problems. Twitter developer Alex Payne is now preaching Scala is the new Ruby, and panning Ruby for its technical foibles:
One of the things that I’ve found throughout my career is the need to have long-lived processes. And Ruby, like many scripting languages, has trouble being an environment for long lived processes. But the JVM is very good at that, because it’s been optimized for that over the last ten years. So Scala provides a basis for writing long-lived servers, and that’s primarily what we use it for at Twitter right now.I've certainly been bitten by Ruby's poor garbage collection. The de facto Ruby interpreter uses a primitive mark-sweep garbage collection algorithm which slowly "leaks" memory over time as the heap fragments. It sure would be nice if Ruby had all sorts of exotic pluggable GC options the way the JVM does. Twitter developer Robey Pointer opines: "With Scala we could still write this really high level code, but be on the JVM." Yes, it sure would be nice if you could use a high level language like Ruby on the JVM.
Except Ruby does run on the JVM with JRuby, and this is something mosts Rubyists I know are aware of. I've been following JRuby pretty closely for the past several months because I am particularly interested in using Ruby for "always on" devices, so I need the compacting garbage collection the JVM provides. JRuby doesn't perform as well as Scala, but it is a fully implemented, viable, and in most cases better performing implementation than the de facto interpreter.
I can only assume someone at Twitter knows about and has used JRuby. Why this doesn't enter into their technology selection process is beyond me. Thanks to JRuby, "the interpreter sucks!" is no longer a valid complaint against Ruby, but that doesn't seem to prevent Twitter, one of the foremost Ruby-using companies in the world, from trashing it. This is ironic considering complaints that "Ruby doesn't scale!" are almost intractably linked to Twitter's scaling problems, while other companies have managed huge Rails deployments without scaling problems. I do not envy the task Twitter has before them and at my job I certainly don't deal with the sheer volumes of data they do (although I do still deal with asynchronous processing of a lot of data, using Ruby), but it's my belief that Twitter's scaling problems have much more to do with the culture at Twitter than they do with Ruby as a language.
At the heart of this Ruby vs. Scala debacle at Twitter is their message queue. Rather than chosing one of the hundreds of message queues that are already available (including ones written in Ruby), Twitter seemed to succumb to NIH and wrote their own. The result was Starling, a message queue which talks the memcache protocol (never mind there's already a message queue that does that too).
Starling is quite possibly one of the slowest and most poorly designed message queues in existence. I work for a company which, among other things, does a lot of message queue-driven asynchronous background processing of data using Ruby processes. When we selected a message queue, we surveyed at least a dozen of them, one of which was Starling. We did some basic simulated load testing, seeing how the queue performed for increasing numbers of readers/writers versus increasing message volumes. Starling's performance was utterly abysmal. As we increased the number of readers/writers to Starling its performance started nearing rock bottom quickly.
As I perhaps somewhat self-aggrandizingly consider myself one of the most knowledgable people regarding I/O in the Ruby world, I decided to peek around the Starling source and see what I discovered. What I found was a half-assed and pathetically underperforming reinvention of EventMachine, an event-based networking framework for Ruby which is the Ruby answer to the Twisted framework from Python. EventMachine is built on an underlying C++ implementation, and while the API it exposes is rather ugly, it's quite fast. This gross oversight was not present in the other message queue available for Ruby, which benchmarked substantially faster than Starling. Eventually Starling would be forked as "Evented Starling" and this gross oversight would be corrected.
As someone who has contributed to the EventMachine project and written my own high performance Ruby event framework, this is my reaction to the design of Starling:
It's not as if it's particularly hard to write a message queue. For shits and grins I wrote my own in Erlang just to compare it to Starling. The result was more or less as full featured as Starling, but performed a few orders of magnitude better, and was 1/10th the size (150 lines of code as opposed to 1500). My queue doesn't perform nearly as well as mature, open source alternatives, but it was a fun exercise to gauge just how badly the Twitter people failed.
Starling was clearly the first attempt of its authors to write a high performance network server in Ruby, and they miserably failed. I've never seen an explanation from Twitter as to why they felt existing message queues were inadequate. However, it became painfully clear that Starling was woefully inadequate:
By mid-2008, one of these Ruby message queues completely crashed and developers needed two and a half hours to shove the dropped Tweets back through the system. When your game is micro-blogging, that's a lifetime.Yes, with absolutely zero experience in writing high performance network servers in Ruby, Twitter's NIH led them to homebrew their own message queue. And surprise surprise, it failed miserably! What was Twitter's reaction? Did they start looking for a better, open source message queue system written by people who are actually competent to develop message queues? No, of course not, more NIH to the rescue:
Then, in his spare time, one developer ported the code to Scala. According to Payne, the Scala queue could process the same message backlog in 20 seconds.Yes, clearly Ruby is the problem, and more NIH is the solution. The result was Kestrel, a new message queue written in Scala which nobody but Twitter uses. It performs a lot better than Starling, though! Just not as well as RabbitMQ, a queue so fast certain crazy people I know are streaming video through it in realtime.
I've never seen Twitter's rationale for writing their own message queue in the first place. Reading the list of requirements given in the Kestrel description, I'm completely confused as to why MemcacheQ does not meet their needs. If you're willing to drop the "use the memcache protocol" requirement there are dozens of queues which would seem to fit their needs, with better performance than Kestrel.
I'm uncertain as to what else Twitter is using Scala for besides its message queue. Given all their myopic and seemingly JRuby-unaware harping on using Ruby for background jobs:
"And that wall was not so much it code but in limitations in Ruby virtual machine. There's a lot of things that Ruby is great at, but long running processes? Particularly memory intensive ones? Not so much."...I'm guessing they are in the process of ripping out all the background jobs and rewriting them in Scala. But the message queue remains the center point of their argument. The failures of the message queue are Twitter's own, not Ruby's.
I would be curious to hear what arguments, if any, Twitter had against JRuby, or other message queues. The public arguments I've seen, and the decision making process I'm inferring from it, seem like an incredibly inept one. This belies something I've heard about those who deal with the Twitter people: their scaling problems come not so much from Ruby but from bad design decisions.
Overall, I think they're missing the point of Ruby. Ruby shines as an automation and "glue code" language, providing you with a swiss army knife that lets you easily integrate many software components writen in whatever language you want into a single, cohesive application. Message queues are commoditized in the software world, and clients exist for virtually all of them in the Ruby world. AMQP, XMPP, Stomp, you name it and chances are Ruby speaks it. The EngineYard folks are doing wonderful things with Ruby and XMPP/AMQP in their Vertebra and Nanite projects. The Twitter folks are... off reinventing message queues in Ruby, then blaming Ruby when their implementation turns out to be slow.
In conclusion... is Ruby a bad language for writing message queues in? Yes, there are much better choices. Message queues are a particularly performance critical piece of software, which requires your language has excellent I/O capabilities and a decent strategy for concurrency. Ruby has neither of these, so it's no wonder Starling fails miserably. But message queues aren't something you should be writing yourself. This speaks much more to Twitter's culture of NIH than it does to Ruby as a language.
Is Ruby a bad language for writing long-running processes? Absolutely not. JRuby provides state-of-the-art garbage collection algorithms available in the JVM to the Ruby world. These are the exact same technologies that are available in Scala. JRuby addresses all of their concerns for long-running processes, but they don't bother to mention it and instead just point out the problems of the de facto Ruby interpreter.
I expect this debate is raging inside Twitter and we're only seeing the surface of it. My apologies to Twitter if there is actually a well thought out rationale for what they're doing, but if so, the public message (and software) you're giving to the world is entirely unconvincing.
Update: If you check the comments you'll see the Twitter folks have clarified their position, and I've created a new post in response. I think their arguments for Scala and Kestrel are certainly reasonable, and their position makes much more sense when it's based on Scala's strengths, not Ruby's weaknesses. Twitter is a great service that I use every day (I mean, I have a Twitter sidebar on my blog and all), despite its occasional stability problems. I wish them luck on their new Scala-based backend and hope they can get these stability problems licked.
150 comments:
I'm glad you mentioned Erlang as messaging plays directly to its strengths (even without mentioning the ease with which it can scale out)
Of the message queues you mention, only ActiveMQ was mature enough to be a reasonable option back in early 2008 when they released Starling. See my more detailed comment on hacker news: http://news.ycombinator.com/item?id=546275
@simon
Yes, but why rewrite it in Scala now when they have more options. It still doesn't make any sense.
Thanks for the blog post.
We can't use JRuby without rewriting all of our gems that rely on native extensions.
We did try other message queues and found them to either not work well at our volume or to lack features (like paging to disk) that we needed.
> We can't use JRuby without
> rewriting all of our gems
> that rely on native extensions.
Don't quite understand this. Isn't the message server pretty stand-alone? Does it need to load lots of gems? Also by rewriting in Scala you automatically lose all your gems....
Tony,
I really enjoyed reading this article. Keep it up!
Ikai
http://www.twitter.com/ikai
Daniel, the port to Scala for starling was purely for performance. Starling didn't rely heavily on third-party libraries. Twitter.com proper does.
Steve Jenson: I don't want to hassle you too much, but your statement is really absurd. "We can't use JRuby without rewriting all of our gems that rely on native extensions." So you wrote the backend in Scala? None of the furor raised over the Twitter move has anything to do with the frontend, which is still running Ruby. Keep that part running on CRuby if it suits you, I really don't care. But the Artima interview listed many points in favor of Scala and against Ruby that could have been remedied by JRuby. You must understand we work very hard to help people understand that many problems with CRuby are solved very neatly by JRuby. If Scala was truly the best option to solve Twitter's problems, so be it...I recognize that Scala is a great tool. But continuing to use CRuby's issues as justification for leaving Ruby while ignoring JRuby really stinks.
Charles, we respect the hard work that you guys have done with JRuby but for the systems that we wanted to build, we felt that we'd get more from a system that compiled to JVM bytecode and could perform on par with Java. We were hoping to also see benefits from Scala's advanced type system. So far, we haven't been disappointed. That doesn't mean there's no place for JRuby at Twitter, we just haven't found it yet. We're open to it.
1. JRuby can compile to JVM bytecode, right?
2. There's no way to know how Twitter as a whole will perform on JRuby without investing significant manpower and performance engineering. The same goes for a port to Scala, Erlang, or C. There ain't no free lunches or silver bullets in performance engineering.
3. It's easy to sit on the sidelines and criticize Twitter for scalability issues. But no matter what kind of architecture or platform you have, when you build a public-facing application with the kind of unregulated load growth that Twitter is supporting, there are going to be performance engineering challenges. eBay's had them, Google's had them, Amazon's had them, Netflix has had them. I'm sure the major online banking servers have too, although you won't hear about them publicly. :)
Eventually you have to take it back to the business and make the hard choices. Sure, there's some interesting computer science / application architecture here, and lots of room for improvement in the underlying Ruby core interpreters. I've profiled them -- I've seen what they do down to the line of code. So has Charlie, at least for JRuby.
But it's a business decision as much as it is a technical decision. Do you regulate load growth? If so, how? Do you throw hardware at it? What happens if the growth stops, as all exponential growth usually does? Who are your customers? What are their needs? What are the priorities?
@steve Your very last comment (you wanted Java speeds and typing) was a valid argument, and the argument should be left at that.
The arguments related to long-running processes, threading, and garbage collection (and now C extensions) are muddling the topic so it cannot be properly argued in good faith.
Steve,
In what ways did ActiveMQ not meet your needs which Starling did?
ActiveMQ is much faster than Starling and supports a disk log. It also speaks the Stomp protocol which has been well-supported in Ruby for quite awhile.
Steve did extensive load and stress testing of ActiveMQ, RabbitMQ, etc. ActiveMQ is actually quite slow (much slower than Kestrel), RabbitMQ consistently crashes with too many producers and too few consumers.
The whole "NIH" argument is an unfair one for services at Twitter's scale. Long ago Twitter reached the point where we run daily into bugs and performance limitations in supposedly enterprise-class open source software. We crash mysql, we crash memcached, etc. all the time.
Scala is a very nice language. It's very fast, faster than JRuby, and it's type system provides some advantages over a dynamic language for certain kinds of applications. Some engineers here prefer it to Ruby, and so weighing the pros and cons, most new network services at Twitter are being written in Scala.
Tony,
We didn't compare ActiveMQ to Starling, we compared it to Kestrel. Robey had already written Kestrel in his spare time and we were going to use it as a more scalable drop-in replacement while we evaluated other queues.
ActiveMQ, in persistent mode, was very slow. An order of magnitude slower than Kestrel. RabbitMQ was speedy but if you put in more messages than you had memory, it would run out of memory and crash.
We also evaluated several commercial message queues but found them lacking in Ruby support.
MemcacheQ wasn't around when we did this evaluation but it's inappropriate due to it's use of Oracle BerkeleyDB which we don't want to pay for just to get functionality we already have.
The commenter 'Nick' works at Twitter and can attest that we spent several weeks going over our options, running extensive load tests, and presented our findings to the team at each stage. We did our due diligence.
It sounds like Twitter did a lot of research and could very well have completely sound reasons for their choices. I think it's time Twitter put together a white paper or presentation on queue services. This would silence a lot of the critics and benefit the community as the research is opened up. I suspect that, if the research is sound and ActiveMQ truly is slow (at twitter scale), then the ActiveMQ community would get it together and fix the issue. This benefits everyone. Twitter becomes a thought leader in large scale message processing and ActiveMQ gets a whole lot better.
Remember when people found the Linux kernel networking stack to be very slow compared to Windows? The Linux people got it together and refactored it to be zero copy and ultimately very fast.
Benchmarks and solid research help everyone. Twitter: please share this. The scientific method has been proven, let's act like good engineers and measure and prove and share.
Totally agree with sethladd. Releasing information about their internal evaluations will both help Twitter's image, and help the community.
The last poster is right; post your findings.
Also, if neither ActiveMQ or RabbitMQ were perfect fits, why not take advantage of their open source nature and fix them? It seems odd to create a greenfield message queueing project when so many open alternatives exist.
Okay, so they weren't perfect in your testing. But weren't they closer than what you had (nothing)?
Alternately, I know the guys behind RabbitMQ do consulting work for money (LShift, I think). You could have farmed the work out and not distracted your internal folks with designing, engineering, building, testing and maintaining another home-grown component.
Release the details. We'll all be better off for it.
I suspect we can release our numbers, hopefully we will do so. But--and I realize I'm asking for faith on your guys' part--give us the benefit of the doubt, set aside your NIH phobia. We had a RabbitMQ guy IN THE OFFICE to discuss our needs.
Existing open source projects aren't sacred. It's OK for there to be yet another one, especially if it has concrete improvements. Contributing back to an open-source project, when it's not in your language of choice/expertise (e.g., Java, Erlang) is not a great option. In our case, Kestrel makes a certain set of trade offs with respect to durability that *MQ doesn't. In Kestrel, the write-ahead log is in memory and is only periodically flushed to disk. In *MQ the log is always synced to disk. Finally, the use of the memcached protocol w/ client-side round-robin is a fundamentally different way of providing scaling and availability than the *MQs, and prohibits hard ordering.
Finally, when you work on a large code-base at scale like Twitter, the integration costs of e.g., moving to Stomp or AMQP can easily outweigh the costs of writing and operationalizing a fully encapsulated service that preserves an existing API (Starling/Memcached). With kestrel, we could simply replace 1 of our N starling servers and see how it behaves. No client code needed to change.
Now imagine a complete port to stomp. Suppose it turns out during our initial deploy that there are major defects somewhere (in the message queue, in the new producer/consumer code, whatever). How do we roll back? We have data in two message queues, producers and consumers at completely different versions, etc.
These issues are complex and reflect interacting with a legacy codebase and weighing engineering trade-offs that you aren't normally concerned with until you're Twitter. So please, give us the benefit of the doubt.
The one thing that still doesn't make sense to me is if your requirements are as high as you claim (which I'm sure they are) how did you ever get by on Starling?
Tony,
We had a much smaller site then and ran a lot more Starlings.
Tony,
Hoo boy. First of all, I hope you've had a chance to read my general reply to the articles about my Web 2.0 Expo talk [1] and this response to a vocal member of the Ruby community [2]. I sound like a pretty unreasonable guy filtered through the tech press and Reddit comments, but I hope less so in my own words.
Secondly, the quote at the top of your post is from my coworker, Steve Jenson, who's been participating in the discussion on this post.
On JRuby: as Steve said, we can't actually boot our main Rails app on JRuby. That's a blocker. Incidentally, if you know of anyone who has a large JRuby deployment, we'd be interested in that first-hand experience. If you don't, it might be a little early to say it would solve all our problems.
It's also incorrect to say that the way JRuby and Scala make use of the JVM is exactly the same. Much like our other decisions haven't been arbitrary, our decision to use Scala over other JVM-hosted languages was based on investigation.
On our culture: if you'd like to know about how we write code, or how our code has evolved over time, just ask us. We're all on Twitter, of course, but most of the engineers also have blogs and publish their email addresses. There's no need to speculate. Just ask. There's not a "raging debate" internally because we make our engineering decisions like engineers: we experiment, and base our decisions on the results of those experiments.
It's definitely true that Starling and Evented Starling are relatively immature queuing systems. I was eager to get them out of our stack. So, as Steve said, we put all the MQ's you think we'd try through their paces not too long ago, and we knocked one after another over in straightforward benchmarks. Some, like RabbitMQ, just up and died. Others chugged on, but slowly. Where we ran into issues, we contacted experts and applied best practices, but in the end, we found that Kestrel fit our particular use cases better and more reliably. This was not the hypothesis we had going into those benchmarks, but it's what the data bore out.
We get a lot of speculation to the tune of "why haven't those idiots tried x, it's so obvious!" Generally, we have tried x, as well as y and z. Funnily enough, I was actually pushing to get us on RabbitMQ, but our benchmarks showed that it just wouldn't work for us, which is a shame, because it advertises some sexy features.
Personally, I'm extremely NIH-averse; I research open source and commercial solutions before cutting a new path. In the case of our MQ, one of our engineers actually wrote Kestrel in his free time, so it was bit more like we adopted an existing open source project than rolled our own. Pretty much the last thing we want to be doing is focusing on problems outside our domain. As it so happens, though, moving messages around quickly is our business. I don't think it's crazy-go-nuts that we've spent some time on an MQ.
I hope my colleagues and I have been able to answer some of your questions. As I said, in the future, please consider emailing us so we can share our experience. Then, we can have a public discussion about facts, not speculation. Perhaps, as commenter sethladd suggested, the onus is on us to produce a whitepaper or presentation about our findings so as to stave off such speculation. Time constraints are the main reason why we haven't done so.
[1] http://al3x.net/2009/04/04/reasoned-technical-discussion.html
[2] http://blog.obiefernandez.com/content/2009/04/my-reasoned-response-about-scala-at-twitter.html#IDComment18212539
Wow, thanks. That was quite a satisfactory response. I'll post a followup blog here in a bit.
RE: forking or improving an existing open source project and integrating it with your systems...
Asked and answered. Thanks for your transparency.
So what I get from these comments from the Twitter guys is that Starling sucked and was subsequently replaced by a new Scala messaging system.
In other words Ruby wasn't the problem, it was Starling (Which as the Twitter guys said was a good messaging system when written but just couldn't handle the increased load in the long run).
Hello, Alexis here from the RabbitMQ team. I am the guy who visited the Twitter offices, that al3x mentioned in his comment above.
First off I would like to second the statement made by some of the Twitter guys above that they do not have an 'NIH' mindset. While some individuals in their team like to code new stuff, which can become a form of NIH, it is true that *as a team* they approach problems systematically.
Secondly, I know something about what the Twitter team do with messaging, and what they don't use messaging for. And I have just read a large number of blog posts and comments about Scala, messaging, Twitter (and Alex's book!). People are making massive assumptions about how Twitter do and don't use messaging. Most of these assumptions are completely wrong. Give these guys a break. They are trying to make improvements in a running system which is scrutinised every minute of every day, for a single sign of failure. This would drive anyone to drink, madness, or worse yet, functional languages ;-)
The choice of language is secondary to the design of any messaging system. RabbitMQ is written in erlang/OTP which like Scala can use a share-nothing model. But this is no guarantee that your messaging system will work well in every possible scenario that any customer could ever use. This is why writing good messaging systems is hard, and in the case of RabbitMQ it leads to our being careful to add major features slowly, because we don't want the product to be compromised by bad designs that are hard to remove later. We have to do things this way because we have a lot of (mostly happy) users.
Now, quite a few of those users have asked us to add a feature called 'page to disk'. We are adding this feature now. 'Page to disk' means that when messages are persistent, they do *not* get held in memory at the same time. Note that in the current version of RabbitMQ, if a message is persisted, then a copy is held in memory as well. One of the RabbitMQ team recently blogged about this here: http://www.lshift.net/blog/2009/04/02/cranial-surgery-giving-rabbit-more-memory (please note that the messages are few but large in order to test the overflow properties of the system)
The scenario in which page-to-disk is needed is as follows:
1. You have relatively slow consumers with durable subscriptions. E.g. they disappear for days at a time.
2. You have to keep all messages that they have not seen yet and cannot flush them on a timeout basis.
3. You have enough producers and data that this fills up the memory of your broker.
4. You cannot, or don't want to, run the broker on multiple machines, e.g. using RabbitMQ clusters.
Since it is not my place to speak about what Twitter actually does under the hood, I shall leave it to readers to figure out when, if at all, these criteria apply to the several ways that Twitter might or might not use messaging.
It's quite easy to write a messaging system that manages balanced transient flows where ingress and egress are similar. Writing messaging systems that work under any combination of flows, on any number of machines, and in multiple different reliability scenarios ... is a more interesting problem. Page-to-disk is a way to make RabbitMQ better and address more scenarios.
If you are reading this and have other ways to improve the broker, please send us information via the mailing list or privately to info at rabbitmq.com, and please be as detailed and concrete as possible.
If you are in SF and want to know more about how you can build a twitter type system using RabbitMQ, we shall be talking about it, a little bit, this Wednesday evening: http://www.bayfp.org/blog/2009/03/25/next-meeting-rabbitmq-wednesday-april-8th-730pm/ (with beers afterwards). We'll just be talking about *messaging* in various scenarios.
I'd like to finish by asking everyone to check out Harper Reed's most excellent new project: http://www.awesomeupdater.com/
Cheers,
alexis
PS: to one person who shall remain nameless, thanks for a completely fatuous tweet. I'll buy you a beer next week if you come to the talk on Wednesday :-)
Looks like the folks over at SecondLife did an evaluation of several message queues and posted their results. Check it out here:
http://tinyurl.com/c8x6z5
@alex> I research open source and commercial solutions before cutting a new path.
I recommended 1.5 million message/second Tervela box through numerous channels, and I don't have any evidence that it was ever considered.
http://www.tervela.com/tmx
Maybe I am cynical, but In the interest of transparency please also note that Alex may also be pimping his own book about Scala which *may* in part help us understand why he is being more vocal in re-opening the debate on 'Ruby v. Scala'.
I am not in any way saying his arguments and experiences are not well thought out (any programmer worth his salt knows there is no silver bullet language), and I won't take a position on Ruby vs. Scala since I have only used one of them.
He does though in fact appear to have a vested interest in this language based religious war (above and beyond his Twitter affiliation) which has proven over several years to provide excellent link-bait...
http://oreilly.com/catalog/9780596157746/
I'm just saying...
"Glenn" has to muddy the waters with his statement about the twitter folks not being all that honest since one of them is writing a scala book.
Give me a break dude, and go off with your tabloid comments elsewhere. Just when folks start to have a reasonable discussion ...
-jpb
Bob: part of research, for us, was considering cost and integration time. See Nick's comments above for why Kestrel ended up being much easier to test than other complete-rewrite solutions. We did appreciate your suggestion.
Glenn: if you search around for what people make on technical books, you'll see that I don't have much to gain from book sales. I'm putting a lot more time into my half of the book than I'll ever make back. But it's well worth it for what I'm learning in the process.
Tony: as the guy who wrote Starling, I'll be nice and simply say that you haven't done your research. Your Picard there is hitting his head over the stupidity of the internal combustion engine.
Starling was written over two years ago (it took a long time to release). It was written in about a day and a half. At the time, no memcache-based queue servers existed, RabbitMQ required knowledge of erlang, and rev and EventMachine didn't exist or were so immature that they were essentially useless. ActiveMQ didn't have Ruby client libraries, and Spread, well. Anyhow.
If you do the math, for the number of queue operations Twitter was doing *two years ago*, Starling is plenty fast enough, because each queue action took several orders of magnitude longer than the queuing / de-queueing itself.
Moreover, you might try turning off the fsync() that is present in the default Starling distribution, which makes it easily four times slower than normal operation. And then you might compare apples to apples, and ensure that your queues are doing the same thing.
And to top it all off, in the README for Starling I wrote:
"Starling is "slow" as far as messaging systems are concerned. In practice, it's fast enough."
It was a case of worse-is-better, and frankly, its existence has been an important part of discussions around message queue design from a usability standpoint. Prior to Starling, queuing was HARD for small organizations, and the agenda was set by JMS and "the enterprise" - oh, there's Picard again.
I'm not going to defend Starling as a great example of high performance and resilient message queue or networking software design, and I tend to recommend RabbitMQ or Kestrel to people looking for a simple queue.
In the future, as Alex suggests, please feel free to email developers of software before making many unsubstantiated and incorrect claims. My email address is and has always been in the Starling source code.
"EventMachine didn't exist or were so immature that they were essentially useless."
That is most certainly not the case. I've been using EventMachine since 2006, and while I am not a fan of the API (hence writing Rev), it was most certainly stable and mature back then.
The EventMachine-based Ruby StompServer was released in late 2006 and outperforms (non-Evented) Starling.
I don't want to pay for Oracle BerkeleyDB either, that's why I use it without giving them money. It is opensource, you know =P
nothingmuch said...
"I don't want to pay for Oracle BerkeleyDB either, that's why I use it without giving them money. It is opensource, you know =P"
It's under a copyleft license which prevents its redistribution along with your software unless you distributed your source or pay them a (very large last time I heard) fee.
One thing I really feel I should say:
For the purposes of my job, we do not need a stateful message queue. We run an automation system which keeps all state in a database. Most of our system is effectively stateless, including our message queues. If our message queues crash, our system recovers from the state in the database.
Twitter, who is running a messaging system, apparently needs to persist state across their entire system. I don't know if the system could be architected in a more stateless manner, but I'll give them the benefit of the doubt and assume they have tried to make their system less stateful. This means all their queues need to be disk logged. The performance tests we performed which I anecdotally cited did not ever use a disk logged message queue intentionally, but in the case of Starling we were as this appears to be the only option Starling provides.
I'm afraid this is an apples-to-oranges comparison and I may be unduly sullying Starling.
That said we were testing a persistent configuration of Ruby Stompserver, which despite being written in Ruby was able to outperform Starling (at the level of ~100 readers/writers)
In Twitter's case it sounds as if they were running a rather large "flock of Starlings" to handle the load. This works, but in our system we run one queue per server.
Twitter is a successful company, therefore, whatever it does, must be 'correct'. If your company is successful then whatever it does is 'correct' even if it is completely different from Twitter.
No tongue in cheek intended. Going toward Scala must be a good thing, otherwise they wouldn't do it.
Results are everything.
why would twitter want to redistribute Berkeley DB itself?
It's perfectly legal to distribute source code that links against it, and even that doesn't seem to be a real concern for an internal product.
The claim that BDB costs money does not really apply in this situation unless they want to sell a product that is prebuilt with it, the way I understand the licensing issues anwyay.
Very interesting conversation. I work on ActiveMessaging, and have used most of the brokers mentioned above.
I'll throw out one more - there is the reliable messaging gem that is lovely for development - persists to disk, very lightweight, and trivial to install and use. I don't think I would begin to recommend for high demand production, as I haven't tested it for such, but for smaller projects and development, I am a big fan.
I know from several other large applications that ActiveMQ is troubled at load, and am not surprised it fell over.
Stomp is not a perfect protocol, such as lacking a good way to rollback message receipt, but there are more than a few impls out there in python, ruby, and java via rabbit and activemq. I always found it disappointing that twitter didn't use the protocol if not the impls out there, as it seems a good fit (short text messages are stomp's bread and butter).
I do understand that twitter is a messaging app at core, so it makes sense to invest in building something, I only wish that they had adopted a messaging spec/protocol such as amqp or stomp for their impl.
Personally, I have high hopes for RabbitMQ/amqp, and that is the next broker/protocol I'll be integrating with ActiveMessaging.
-Andrew Kuklewicz
Any messaging server where IO doesn't dominate to the point where language choice is irrelevant is badly written.
Writing one in Ruby is fairly simple. I wrote a Ruby Stomp server for inhouse use years ago, and it was trivial to optimize it to the point where the time spent in my Ruby code was less than 10% of the total time spent - the rest of the time was spent in the kernel handling IO syscalls.
"Any messaging server where IO doesn't dominate to the point where language choice is irrelevant is badly written." -- Vidar
"For every complex problem there is an answer that is clear, simple, and wrong." -- H. L. Mencken
:)
But seriously, building a scalable architecture for something as complex as a messaging server involves more than just "throwing cores at it until it's I/O bound". :) The optimum case, which you will never achieve except "on the average", is for the processor and I/O utilizations to be approximately equal and for the number of "users" to be at a point known in queuing theory as "N*"
This is called "asymptotic bounds analysis" (ABA) and can be found in lots of places, but a good start is
http://www.cs.washington.edu/homes/lazowska/qsp/Images/Chap_05.pdf
HTH :)
So Twitter is awesome for Taking traffic to your website . It is very
simple to setup and it's a fun positive way to keep in contact with
people. To get more followers on twitter check out this amazing
tool, Twitter Traffic Machine.
Apache ActiveMQ is highly configurable - you can always make it scale or perform better - depending on your use case: see Scaling ActiveMQ
FWIW, I'd like to know how ActiveMQ did not meet the needs of Twitter so that we can use that information to improve ActiveMQ. There has been no discussion of configurations or topologies or use cases so I'm not even sure where to begin.
FYI, ActiveMQ was born out of the Apache Geronimo project but actually began life at the Codehaus. The first releases of ActiveMQ began appearing back around 2003 or 2004. It was only later in 2005 that we moved it to the Apache Software Foundation.
There are some comments about RabbitMQ from Alexis regarding the page-to-disk feature so I can address that. ActiveMQ already has this feature so that messages (and even references) are not held in memory (see message cursors here: http://bit.ly/10u5WJ).
The additional comments from Alexis are exactly correct. Building a messaging system that will suit any use case, running on any number of systems, using any topology with all the necessary features is a difficult task and certainly takes time to perfect.
There was also a comment from Alex Payne that experts were contacted. Was anyone from the ActiveMQ community contacted?
Since the research has already been done, please let us know why ActiveMQ did not work for Twitter so that we can improve it.
It's a fact that RoR/Ruby is slower than Scala, why kill the messenger for the message? It's pretty humorous how all the RoR hypesters are now jumping off a sinking ship.
I'm a little late to the party, but this is a wonderful article; thanks! Your words played a part in my selection of RabbitMQ in a web-app I'm working on. I just published a post on my blog making reference to this great article: SeatSync Engineering: Choosing Platforms.
Now Akka 2.0 is released to scale Scala into the next leap!
Hibernate Online Training Hibernate Online Training Hibernate Training in Chennai Hibernate Training in Chennai Java Online Training Java Online Training Hibernate Training Institutes in ChennaiHibernate Training Institutes in Chennai
Java Training Institutes Java Training Institutes
Java Spring Hibernate Training Institutes in Chennai J2EE Training Institutes in Chennai J2EE Training Institutes in Chennai Core Java Training Institutes in Chennai Core Java Training Institutes in Chennai
Interesting and informative article.. very useful to me.. thanks for sharing your wonderful ideas.. please keep on updating..
Android Training in chennai | IOS Training in chennai
This website of yours is really helpful it provided us with massive valuable information to work on there are many impressive post that you have done in this site which we found it as treasure in details please keep his excellent and delight job in further updates thank you very much indeed
eCommerce Product Service
دانلود مرورگر گوگل کروم Google Chrome 42.0.2311.90 Final + Portable
دانلود فیلم The Search 2014 با لینک مستقیم
دانلود فیلم Bark Ranger 2015 با لینک مستقیم
Penirum
Penirum Asli
Jual Penirum
Obat Penirum
Penirum Original
Ciri Penirum
Harga Penirum
Khasiat Penirum
Penirum Kapsul
Very Nice !! Keep Updating Article like this !! Wonderful content i got from this website.
Thanks for your informative article. Your post helped me to understand the future and career prospects. Keep on updating your blog with such awesome article.
MCA Project Center in Chennai | MCA Project Center in Velachery
Very nice post I really enjoyed it...You can also visit my website for
Call girls in Bangalore
Call girls in Kolkata
Call girls in Lucknow
Call girls in Jammu
Call Girls in Chandigarh
Very nice post I really enjoyed it...You can also visit my website for
Escorts in Bangalore
Escorts in Kolkata
Escorts in Lucknow
Escorts in Jammu
Escorts in Chandigarh
Escorts in Guwahati
Escorts in Ranchi
Escorts in Gurgaon
Escorts in Chandigarh
Escorts in Pune
Loved your post...You can also visit my website for
Bangalore escorts
Kolkata escorts
Lucknow escorts
Jammu escorts
Chandigarh escorts
Guwahati escorts
Ranchi escorts
Gurgaon escorts
Chandigarh escorts
Pune escorts
You need the CCTV installation London services to prevent crime and act in the event of crime, we install and maintain CCTV, Burglar Alarms, and Wireless, Fire Alarms, Door Intercom and Access Control systems. Over 10 years’ experience in security industry! Call us now on 07867860150 or Visit our website:
CCTV companies London
سفارش دوخت سرویس آشپزخانه
دوخت سرویس آشپزخانه طرح گل گلی
Norton customer service
Mcafee customer service number
Polular KEWWORDS for SEO of Massage Parlor Website in Delhi & NCR region are :
Body Massage in Delhi, Massage Parlor in Delhi, Massage Center in Delhi, Body Massage in Mahipalpur, Massage Parlor in Mahipalpur, Massage Parlor in Aerocity, Body Massage in Aerocity & Body Massage in Paharganj
For Body Massage you can click on Body Massage in Mahipalpur,
Massage Parlor in Mahipalpur & Body to Body Massage in Mahipalpur
Following are the link of 100% genuine and popular Spa in mahipalpur, Massage Parlor in Mahipalpur, Spa in Aerocity, Massage Parlor in Aerocity, Spa in Vasant Kunj & Massage Parlor in Vasant Kunj
I appreciate your blog. This is the first time I am visiting your post. really it's so interesting to read. Please keep up writing. Thanx for sharing.
lenderslists
review for loans
SpreadtrumSP Flash ToolStock RomBest Online StoreService HPBuku Servis HPKredit HPToko OnlineHP HangKomponen HP
Bisnis
indonesia
lampung
Lampung
Lampung
lampung
Elektronika
Bisnis
Very nicely written.Thanx for sharing
EveryHourLoans
best permanent makeup los angeles
microblading eyebrows los angeles
best microblading los angeles
microblading los angeles
eyebrow microblading los angeles
permanent makeup eyebrows
best microblading in los angeles
microblading los angeles ca
permanent makeup los angeles
eyebrow microblading atlanta
microblading atlanta ga
best microblading atlanta
eyebrow tattoo atlanta
permanent makeup atlanta
microblading atlanta cost
eyebrows atlanta
permanent eyebrows atlanta
brows atlanta
eyebrow shaping atlanta
permanent eyebrows atlanta
best permanent makeup atlanta
microblading eyebrows atlanta ga
makeup artist atlanta ga
scalp micropigmentation services in atlanta
permanent makeup atlanta
scalp micropigmentation atlanta
permanent makeup services atlanta
best scalp micropigmentation atlanta
Ignou synopsis
Ignou MBA synopsis
Ignou project
Ignou PGDDM synopsis
Ignou report
Ignou MAPC synopsis
Ignou MAEDU synopsis
عزل خزانات بالمدينة المنورة عزل خزانات بالمدينة المنورة
CCTV Installation systems have been used in such applications as crime prevention and traffic monitoring for motor vehicles or for people (such as in schools or office buildings).
#CCTVInstallation, #CCTVInstallationLondon, #CCTVInstallationnearme, #CCTVCameraInstallationnearme, #HomeCCTVInstallation, #HomeAutomation, #HomeAutomationSystem, #BesthomeAutomationSystem, #HomelightingAutomation, #SmartHomeAutomation, #HomeAlarmSystemInstallation, #HomeAlarmInstallation, #HouseAlarmInstallation, #BurglarAlarmSystem, #BurglaAlarmInstallation
CCTV Installation London
Bài này thực sự quá hay
https://ngoctuyenpc.com/man-hinh-may-tinh-24-inch
https://ngoctuyenpc.com/mua-ban-may-tinh-cu-ha-noi
https://ngoctuyenpc.com/mua-ban-may-tinh-laptop-linh-kien-may-tinh-cu-gia-cao-tai-ha-noi
https://ngoctuyenpc.com/cay-may-tinh-cu
ดิมพันได้สะดวกรวดเร็วกว่า 928bet สมัครสมาชิก ดูบอลสด วิเคราะห์บอลฟรี ดูหนังออนไลน์HDไม่มีโฆษณาคั่น
I like twitter and use it every day. I post there and re-tweets some funny tweets. Sometimes I buy twitter likes from this nice site. I like this site because I can get twitter likes by very good price
thanks what a nice topic...
mymember website
Nice Post....Thank you for sharing wonderful Post...
Buy mobile is not easy when you have little money in your hand. So you can search in Quikads; a classified ads platform in Bangladesh. Where you will get so many ideas about Used phone in bd.
Aivivu chuyên vé máy bay, tham khảo
gia ve may bay di my
vé máy bay từ mỹ về việt nam hãng eva
vé máy bay từ Hà nội đi Los Angeles
lịch bay từ canada về việt nam
I sometimes visit your blog, find them useful and help me learn a lot, here are some of my blogs you can refer to to support me
bài thơ viết vè cuộc sống thời nay
phát tờ rơi hà nội
chơi cờ tướng
bắn cá thần tài
no hu doi thuong uy tin
lam cavet xe xe máy giá rẻ
I would make video how Google talks to Twitter and post it on tiktok. It will be very funny as for me. I will get many likes for this video cause I have many followers. I read how to get followers from here http://cascadebusnews.com/followers-that-will-show-you-great-support-on-your-way-towards-online-popularity/
Custom Printing Services co.uk. it is the best printing services and the follow my website new technology printing in the best works try the link spoken. thanks cosmetic packaging boxes | cosmetic packaging boxes
I'm glad to know your website, and nice to meet you all. this is my website
bài thơ về duyên nợ tình yêu
ban ca doi thuong
top game slot doi thuong
lư hương đá
Amazing product thanks for sharing with us It is very informative. If you need any type of boxes, you can visit the link.
printed E Liquid boxes
eco Eyelash packaging
http://www.mountabuescorts.com/bhuj-escorts.html
http://www.missmountabu.com/bhuj-escorts.html
http://www.varshachowdary.com/bhuj-escorts.html
http://www.rajkotescorts.in/bhuj-escorts.html
http://www.sexyhema.in/bhuj-escorts.html
http://parulbehl.in/bhuj-escorts.html
http://www.nayraescorts.com/bhuj-escorts.html
http://sexybindu.in/bhuj-escorts.html
http://damanescorts.in/bhuj-escorts.html
http://callgirlmountabu.com/bhuj-escorts.html
http://mountabuangels.in/bhuj-escorts.html
abu road escorts service
abu road escorts service
abu road escorts service
abu road escorts service
abu road escorts service
abu road escorts service
abu road escorts service
abu road escorts service
abu road escorts service
abu road escorts service
abu road escorts service
silvassa escorts service
silvassa escorts service
silvassa escorts service
silvassa escorts service
silvassa escorts service
silvassa escorts service
silvassa escorts service
silvassa escorts service
silvassa escorts service
silvassa escorts service
silvassa escorts service
silvassa escorts service
independent kolkata escort||
call girl contact number kolkata||
يعد تنظيف الستائر من المهام المنزلية الشاقة التي تواجهها أي أم لصعوبة القيام بها، وكثيرًا ما تؤجلها لانشغالها المستمر أو خوفًا من إتلافها، ما يزيد الأمر سوءًا ويتراكم المزيد من الأتربة والغبار على الستائر. ورغم أن الستائر أجمل ما يميز ديكور منزلك ومن أساسيات الديكور بالمنزل، إذ تعطي لمسة أنيقة وجذابة للمكان، فإنها كذلك من أكثر العناصر التي تلتقط الأتربة بسهولة، ويصعب تنظيفها لعدم قابلية بعض أنواع أقمشتها للغسيل.
شركة تنظيف ستائر بالرياض
شركة مكافحة الحمام بالرياض
شركة تنظيف مكيفات بالرياض
Your work is very important to me so I liked it. If you like pets you can see here Wild Animals.
Khá buồn
tư vấn điện
công ty tư vấn điện
nhiệt điện
english grammar for competitive exams
I really enjoyed reading this article. Keep it up!
Beauty Salon Near Me
Piercing Near Me
Laser Hair Removal Near Me
Waxing Near Me
Thanks for your informative article.
Tire repair near me
Truck repair shop near me
Alignment near me
roadside assistance services
Trailer repair
Điều anh mang đến quá hay
What is PP (Polypropylene)? Its Application In our Life
Learn more about FIBC bags
What is Flexo printing technology? Why did FIBC manufacturers choose this technology?
Những chia sẻ quá hay
Nhựa PTFE
bạc hợp kim đồng
Trục con lăn
Nhựa UHMW PE
Nhựa PA6
quá kinh khủng
bao fibc
bao jumbo 1000kg
công ty bao bì jumbo
this is piya sen thanks for sharing your best information
Wonderful blog thanks to share here i like this so much.
we are Bella spa in Bangalore and providing massage in Bangalore to fulfil needs visit once here. Female to male spa near me
Your comment is very beneficial for the future, you have written in a very beautiful way, you have an inspiration for the youth who come to your comment is really very beautiful, nowadays children do not know where they are wandering, no one can make a comment like you. The post is very different.
Gurugram Phase 3 Girls Desire
Indirapuram Dating Girls
Cheap Price Girls Manesar
vaishali Dating Girls
Noida Cheap rate Girls
Russian Girls Gurugram
Ardee City Blue Eyes Girls
Arjun Nagar Model Girls
To write a beautiful post it is very important to write a beautiful container and have prepared a very good design and I got a lot of inspiration from your post and I would also like to post like you in my life.
Ist Time Sex Girls Gurugram
Gurugram Dating Service Sector 29
Dwarka Dating Service
Gurugram Private Sexy Service
Adult Rooms Gurugram
Gurugram Girls Numbers
Gurugram Girls Service Sector 15
Delhi Airport Area Girls Service
Indirapuram Girls Service With Photos
Spa69 is top most Body To Body Massage service provider which is kept privacy of customer in a good manner to give best top most types massages by expert therapists.
Visit massage near me
Skin well being requires sustenance sometimes. Standard spa treatment prompts the shining and sound skin. That is most likely the motivation behind why body spa is so well known among ladies.
Visit Female to male spa near me
Spasweety is the best Body to body massage spa near me. We are an award-winning spa, and have been recognized by many organizations for our achievements. Our services are designed to suit a wide variety of needs and budgets, so there's something for everyone!
We can help you find the best Body massage spa near me service for out-call services to keep your spa experience going at home.Nuru massage
Now get your male massage services in indhiranagar from expert male therapist at best prices.Male client can get comfortable service with the male therapist in your locality from massage Izspa.
Visit body to body massage spa near me
Lishasingh is a massage therapist from Bangalore. He has worked over the last few years to provide top customer service and support, for both male and female customers.He is always striving to become a better version massage parlour near me of his self by ensuring high quality control throughout the day.Obedient6 minutes ago
In South Hyderabad You can enjoy the benefits of day spas, which mean all day for your own relaxation. You can take advantage of these spa services in hyderabad's luxury hotels, health clubs department stores, or spa centers. The models are charming to take care of and pamper your body. There are many luxurious benefits , like a massages and body wraps if you decide to not wear clothes. Massages are performed using aromatherapy and vitamin-rich oils. There are treatment for your body, beauty tips, and skin treatments. In addition you will also get the luxury of a hot tub bath body to body massage centres in hyderabad that takes away all fatigue and stress.
Female to male spa near you 24 hours provides professional spa treatments that will melt away your stress. Our professional therapists will pamper you to make sure that you feel relaxed, rejuvenated and looking your best.
female to male spa near me 24 hours
well athe tej section massage near me
With us, you will not only receive a complete body massage, but also other options like Foot Massage as well as Body Scrubs and Face Pack. Our spa near to me prices are reasonable so that anyone can enjoy our services with no trouble.
ignou mapc project
ignou bts project
mttm 16 dissertation
ahe 01 project
Thanks For Sharing Breaking News In Hindi
Thanks for sharing information Entertainment News In Hindi
Thanks for sharing information Business News In Hindi
Thanks for sharing information Sport News In Hindi
Thanks For Sharing AUTO News In Hindi
Nice knowledge gaining article. This post is really the best on this valuable topic.
Our Bangalore girls are beautiful and dedicated to providing you with an unforgettable experience. They make sure that you leave happy, with a smile on their face, and clients love them for it.
You can enjoy the real fun with our beautiful Bangalore Companion as they know how to make it happen. They will make sure that you get what you want and need, even if what you want is just some funny moments of your life.
very good blog Visit spa near to me
Female Companions In Mumbai can be found in a number of different places. Many of the city's top hotels have companion services that can connect you with a beautiful girls to accompany you during your stay. In addition, there are a number of agencies that specialize in providing companionship services to businessmen and other high-end clients. These agencies usually have a wide selection of models and other attractive girls to choose from.
Joining Mumbai Girls is a great way to meet new people and make great friends. You can expect to meet a lot of different girls with different backgrounds and interests. This is a perfect opportunity to expand your social circle and meet new people. Mumbai girls is a great way to meet new friends and have a great time.
Our Female Companion Bangalore is always ready to make your time together unforgettable.
If you are looking for a fun and naughty companion to spend some quality time with, then Mumbai companion is the right choice for you. Our girls are not only beautiful but also intelligent and fun-loving. They will make sure that you have a good time, and they will always be ready to please you.
Our Ranchi Companion is tailored to fit your needs and desires. Whether you're looking for a romantic dinner date or a wild night out, our Companion can offer you an unforgettable experience. We understand that each client is unique, so we strive to create individualized experiences that cater to your individual tastes.
The Distance Learning Centre in Delhi is a place where people can pursue their studies through distance education. This type of educational institute is located in Satya Niketan. It offers distance education courses in various fields, such as IT management and business. Education is an essential part of human development, as it determines your life chances and career options. Education provides you with a solid foundation for advancement and can lead to a rewarding career.
Dayitwa Education is committed to providing the necessary Online learning Education to reach the highest platform.
This institute offers a variety of courses for both undergraduate and postgraduate students. This distance learning center in Satya Niketan is accredited by Many Universities and regulated by the same rules as the other constituent colleges. Correspondence education is an excellent option for those who are unable to attend regular classes. During this type of study, you receive course materials by post and return them to the authority for evaluation. There are a number of distinguished institutes in Delhi that provide correspondence education.
Correspondence colleges in Delhi offer a convenient option for completing your education without interrupting your regular job.
School Support Program The Distance Learning Center in Delhi is where
individuals can seek after their examinations through distance training. This kind of insructive organization is situated in Satya Niketan.It offers distance training courses in different fields, like IT the board and business. Training is a fundamental piece of human turn of events, as it
decides your life possibilities and vocation choices. Instruction furnishes you with a strong starting point for headway and can prompt a remunerating vocation
Discover Our Top-Ranked MBA Program – MBA Distance Education
A Distance MBA is an online-based MBA program. MBA Distance Education course is designed in such a way that no need to attend classes at the college campus. We offer a comprehensive array of distance learning programs such as; MBA, law, and many more at discount prices. Because you’ll be able to take your courses online, you’ll be able to earn your degree while working at your current job.
Dayitwa Education provides the facility of Post Graduate Courses in Distance Education. Through this, you can get an academic qualification by studying part-time. You can get a valuable education without sacrificing your time for work or family commitments. If you're ready to take your career to the next level, a bachelor's degree in business may be all you need. But with so many options out there, it can be tough to find the right program. That's where we come in!
At Dayitwa Education, we offer an online MBA degree that will help you advance your career. Our MBA distance education program offers a degree from one of India's top-ranked universities, along with an on-campus interview and personalized guidance from our team of experts. You'll be able to earn your degree while working remotely, so you can focus on growing your business instead of taking time off work.
Dayitwa Education is here to educate you.
We are a leading online MBA distance education provider in India. We offer accredited courses and degrees from top-ranked universities in India, at an affordable price. If you're looking for an MBA degree, we will help you find the best university that fits your needs and budget.
If you're ready to apply, visit our homepage today!
We connect you with the best accredited MBA colleges and universities in India through our partner network. Apply today!
Top diploma programes
Bachelor of Business (BCOM)
Degree:Bachelor
3 year duration, offline
degree in the arts (BA)
Degree:Bachelor
3 year duration, offline
Computer applications bachelor's degree (BCA)
Bachelor's degree, three years, online mode
The most reputable supplier of distance education is Masters of Commerce (MCOM), which helps students change their occupations and prepare for the future.
The most respected distance education provider offers a Masters in Computer Application (MCA) programme that helps students change careers and get ready for the future.
Masters of Arts (MA) programmes are the most dependable source of distance learning institutions, helping students switch occupations and get ready for the future.
If you have any legal doubt visit us our SRIS law group. Pls contact us 888-437-7747
Distance Learning if there is a time and physical gap between the teacher and the student.
Awesome article. Thank you so much for sharing with us. keep sharing this type of articles in future..
how to unlock steering wheel without key
we are a mainly manufacturer of thermal lamination film,, tinsel garland, glitter powder and gift wrapping paper etc
The Sell Mergerswebsite is the fastest growing and the most dynamic portal dealing with core businesses in all segments of the trade. A platform where energies combine, business ideas get wings, dreams get fulfilled, people meet, where interactions have meanings, where business seekers get together to create un- paralleled value
www.sellmerger.com
Learn digital marketing skills to implement them on your website and social media to generate traffic and get maximum ROI. We teach 50+ modules in our Masters in Digital Marketing Course along with 02 Months onboard mentorship training session under our expets digital marketers for Students, Working Professionals, and Entrepreneurs.
female to male massage in hsr layout encourage endorphin release through close contact and gliding motions, which promote muscular relaxation, ease tension, and treat pain.
Take a refreshing dip in pools or hydrotherapy circuits, or engage in yoga and meditation sessions. it will be available only lisha. visit body to body massage spa near me
Among the best massage techniques, a deep b to b massage centre near me tissue massage is applied with forceful strokes that help release strains and knots in the deeper layers of muscles and connective tissue. To perform this massage, a therapist slowly presses the fingers into the skin
Nice Blog thank you
As Regard:-
xnxx
sex videos
x videos
xxx videos
indian sex video
Cultural Diversity: Examining how differentfemale to male spa near me cultural approaches to bodywork intersect with and influence neuromuscular massage techniques.
Massage therapy can be used as a treatment full service massage in bangalore or management strategy for an individual with a terminal illness.
Hi, we are Kay Iron Works At Kay Iron Works, we are pioneers in manufacturing and supplying top-of-the-line industrial plant machines such as sugar plant machines cement and fertiliser plants, paper plants, material handling machines, telecom machinery, EOT cranes and waste tyre pyrolysis plant manufacturer in india. That drive the wheels of progress. With a legacy spanning decades, our company stands tall as a beacon of engineering excellence. Now, we extend our reach to the digital realm, crafting compelling social media profiles for businesses across the globe. Embracing innovation, we leverage our industry expertise to curate engaging content, foster meaningful connections, and amplify brand presence. Trust Kay Iron Works to forge a powerful online identity that reflects the strength and reliability of your industrial operations. Together, we build a brighter future for your business.
Nice blog. I have been searching for this kind of blog.
Looking forward to checking out more. Keep sharing such good stuff.
Regards. Kindly visit on - https://ivfsurrogacy.com/stimulated-ivf-treatment-india/
Proponents say shiatsu massage can help relieve sensual massage in hyderabad blockages at these acupressure points.
Alliance Organics LLP is the largest Blue Pigment Manufacturer In India. We are leading blue pigment exporters in India. The best Pigment Manufacturers in India export the best quality blue pigment for all requirements. We are the Pigment Blue 15 Manufacturer & supplier with all versions like pigment blue 15:0, pigment blue 15:1, pigment blue 15:3, pigment blue 15:4. You can rely on us for choice and quality for all your pigment needs such as Offset Inks, Solvent Based Inks, Water Based Inks, Corrugated Paper Inks, Textile Printing, Plastics, Industrial Coatings.
What we know is that exercise in general can help, and spa with happy ending in punefocusing on core muscles may provide some additional benefit.
Trikal Info is an online betting platform in India.
Visit- lotusbook io
Welcome to CMMCXPERTS, your premier destination for comprehensive IT support services in Los Angeles. Specializing in both general IT support and managed IT services, we are dedicated to ensuring that your business thrives in the ever-evolving technological landscape.
At CMMCXPERTS , we understand the critical role that technology plays in the success of modern businesses. Our team of experts is committed to providing top-notch IT support tailored to meet the unique needs of businesses in Los Angeles. From troubleshooting and resolving day-to-day technical issues to implementing proactive solutions for long-term success, we have the expertise to keep your operations running smoothly.
Our focus on "IT Support Los Angeles" and "Managed IT Support in Los Angeles" reflects our commitment to delivering a comprehensive suite of services. Whether you are a small startup or a large enterprise, our solutions are designed to enhance your IT infrastructure, improve efficiency, and ultimately contribute to your business growth.
Choose CMMCXPERTS for reliable, responsive, and results-driven IT support in Los Angeles. Let us empower your business with the technological expertise it deserves, so you can navigate the digital landscape with confidence and achieve new heights of success.
Surprise Your Loved Ones With A Premium Gift Hamper. Buy This Luxury Indulgence Premium Gift Hamper Online At Best Price In India From OasisBaklawa
Post a Comment