Kyle Banker
fab538ed5e
minor: alias #read_primary? with #primary?
2011-01-17 13:37:41 -05:00
Kyle Banker
0d91faf6b1
RUBY-226 minor: license update
2011-01-17 12:26:32 -05:00
Kyle Banker
af43e9c2ce
RUBY-255
2011-01-17 12:06:03 -05:00
Kyle Banker
a197ea7852
RUBY-219 minor: use opts instead of options throughout
2011-01-05 11:30:20 -05:00
Kyle Banker
4d2d0a26af
minor: docs
2011-01-03 14:06:41 -05:00
Kyle Banker
4e5b1a7d23
RUBY-205 RUBY-150 Support new connection URI options
2010-12-30 15:40:50 -05:00
Kyle Banker
9da68bb3db
RUBY-189 use result of ismaster's maxBsonObjectSize
2010-12-29 18:06:31 -05:00
Kyle Banker
b77b3fe1e6
RUBY-215 added Connection#read_primary? and ReplSetConnection#read_primary?
2010-12-29 13:01:05 -05:00
Kyle Banker
70135a6b67
minor: docs
2010-12-15 14:15:49 -05:00
Kyle Banker
6196c8728a
RUBY-206 handle wtimeout behavior on 1.7.3
2010-12-15 14:15:20 -05:00
Kyle Banker
7ee45f4340
Removed three unused methods from Connection
2010-12-15 12:41:33 -05:00
Kyle Banker
9ea8fe98b7
minor: cleanup and organization of Connection classes
2010-12-15 12:36:43 -05:00
Kyle Banker
39b9656fc4
Fixed request id checking for threaded inserts.
2010-12-15 12:12:51 -05:00
Kyle Banker
5860265cc9
Merge branch 'repl_set_connection'
2010-12-14 17:40:49 -05:00
Kyle Banker
7629cf30f0
Ensure that we close connection if receive raises any errors.
2010-12-14 15:53:59 -05:00
Kyle Banker
236d4a821f
More connection refactoring. Updates to repl_set_manager.
2010-12-14 13:14:45 -05:00
Kyle Banker
6db5bb2f51
Test request and response ids match
2010-12-13 17:54:28 -05:00
Kyle Banker
27b410f869
ReplSetConnection updates
2010-12-13 14:07:32 -05:00
Kyle Banker
08b7cddc81
Initial ReplSetConnection checking. Refactoring.
2010-12-10 16:00:35 -05:00
Kyle Banker
b63250e6e4
Fix for connections to replica sets with 1 secondary and 1 arbiter
2010-12-10 11:12:18 -05:00
Kyle Banker
5930c500b4
RUBY-208 test for connection failure. Minor test fix.
2010-11-30 12:36:45 -05:00
Kyle Banker
1a14156206
minor: cleanup
2010-11-29 14:06:38 -05:00
Kyle Banker
8aaed130d6
Cleanup for distributed reads on replica sets.
2010-11-24 13:49:34 -05:00
Kyle Banker
c5862da061
minor: test fix
2010-11-23 13:37:29 -05:00
Kyle Banker
add9779fa0
Select secondary read node randomly
2010-11-19 18:26:38 -05:00
Kyle Banker
1e57ca90e1
Initial commit for reads from rs secondaries
2010-11-16 15:43:59 -05:00
Kyle Banker
ced3bfbfe8
Update and remove return error object in safe mode
2010-11-09 13:07:01 -05:00
Kyle Banker
68af3dbe8f
Allow the setting of safe mode globally on the Connection,
...
DB, and Collection levels. The safe mode setting will
automatically be inherited down the hierarchy Connection ->
DB -> Collection -> (insert, update, remove). This default
can be overridden at any time. Connection#safe, DB#safe, and
Collection#safe will yield the current default value.
2010-11-03 17:36:08 -04:00
Kyle Banker
f7d151c8dc
minor: doc fixes
2010-11-03 15:32:19 -04:00
Kyle Banker
d6f8f9d41a
Allow specification of replica set name on connect.
...
Raise ReplicaSetConnectionError if expected name doesn't match set.
2010-11-03 15:12:15 -04:00
Kyle Banker
2939932526
close connection when safe mode insert results in 'not master'
2010-10-29 23:18:49 -04:00
Kyle Banker
424f08af5e
close connection on exception on safe insert
2010-10-29 17:52:15 -04:00
Kyle Banker
e416e05fc7
RUBY-190 bug fix for unavailable nodes on Connection#multi
2010-10-21 14:33:48 -04:00
Kyle Banker
a905c3f1f2
RUBY-191 fix to pass options to new db with Connection#db
2010-10-21 13:27:57 -04:00
Kyle Banker
80044b9a58
RUBY-187 All tests can now use custom host and port;
...
Minor test fixes.
2010-10-13 17:09:23 -04:00
Kyle Banker
f7a97a0db0
Removed deprecated Connection methods
2010-10-04 12:16:11 -04:00
Kyle Banker
7ad280c2cb
RUBY-184 Connection#locked?
2010-10-04 11:38:20 -04:00
Kyle Banker
4141331f79
RUBY-184 fsync lock helpers
2010-09-28 12:15:45 -04:00
Hongli Lai (Phusion)
b474b29d35
Optimize Mongo::Connection#receive_message_on_socket and #receive_and_discard_message_on_socket: avoid creating initial input buffer up front so that IO#read only needs to allocate the buffer once.
2010-09-14 10:37:08 -04:00
Hongli Lai (Phusion)
6316c939d5
Optimize Mongo::Connection#send_message_on_socket: don't slice the input when not necessary.
2010-09-14 10:36:54 -04:00
Hongli Lai (Phusion)
87e6d578c1
Optimize Mongo::Connection#add_message_headers by packing data directly instead of using ByteBuffer.
2010-09-14 10:36:40 -04:00
Hongli Lai (Phusion)
0585aa1aae
Fix MongoDB::Collection #insert_documents, #update and #remove and MongoDB::Connection #receive_header and #last_error_message: usage strings as much as possible instead of byte arrays, otherwise performance really suffers.
2010-09-13 10:51:53 -04:00
Hongli Lai (Phusion)
c6206eddf4
Optimize MongoDB::Connection#receive_response_header by using raw string operations and unpack() instead of the slower ByteBuffer.
2010-09-13 10:50:39 -04:00
Hongli Lai (Phusion)
e1bf168767
Optimize MongoDB::Connection#receive.
...
It doesn't do anything with the header. So instead of parsing the header,
just read the header data and discard it.
2010-09-13 10:50:25 -04:00
Hongli Lai (Phusion)
2291a59fcc
Optimize Mongo::Connection#read_documents by using raw string operations and unpack() instead of the slower ByteBuffer.
2010-09-13 10:50:16 -04:00
Hongli Lai (Phusion)
117ce2389c
Optimize receive_message_on_socket for the optimistic average case where 1 socket.read() operation receives all requested data. Also fix some Ruby 1.9 encoding issues in that function while we're at it.
2010-09-13 10:48:32 -04:00
Mislav Marohnić
56f37e49b6
replace usage of returning
with each_with_object
...
`each_with_object` is a Ruby 1.9 method, here re-implemented in core_ext.rb
in case it's missing (for older Ruby versions). Using `returning` is bad in
combination with Ruby on Rails because each usage of the method will emit
a Rails deprecation warning. This might be considered an Active Support bug,
but it's better to avoid using `returning` altogether and use `tap` from
Ruby 1.8.7, also re-implemented here in case it's missing.
Since existing usages or `returning` were better suited for `each_with_object`
than `tap`, they were rewritten using the former instead.
2010-09-13 01:10:38 +08:00
Kyle Banker
300b442a94
Create logging message only when a logger is passed to the Connection.
...
Results in a pretty significant performance improvement.
Many thanks to Matt Taylor for noticing the unusual glut of calls
to ObjectId#to_s. See here: http://unhalting.com/?p=18
2010-09-08 14:27:27 -04:00
Steve Sloan
dfcf8d9d60
Moved thread and socket classes into Connection for easy overriding.
...
This is necessary for use under em-synchrony, which uses Fibers instead of Threads and EventMachine instead of blocking sockets.
2010-08-24 14:35:21 -04:00
Kyle Banker
5cbec4e5b6
RUBY-161 accessors for hosts in a replica set by node type
2010-08-24 11:20:54 -04:00