[
https://issues.apache.org/jira/browse/ZOOKEEPER-1147?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13579681#comment-13579681
]
Thawan Kooburat commented on ZOOKEEPER-1147:
--------------------------------------------
bq. What's the reason for having the config option to disable local session
upgrade? Did you see a specific need for this?
In our largest deployment where we have a very large number of clients, we know
that clients connecting via the observers is supposed to be local session only.
So this is more like a safeguard against someone accidentally create lots of
ephemeral nodes and global sessions.
bq. Given some of the discussion above (more frequent expiry), it seems to me
that we should make sessions global by default and provide an option to
ZooKeeper(...) to enable local session usage. On the flip side making sessions
local by default will result in everyone seeing an improvement w/o need for
code changes (client side I'm saying). That said, it seems that for most people
global vs local session is not an issue. For the small subset of users where it
is an issue they could enable the local session support via a parameter, a very
simple code change for users on the client. Thoughts?
Vast majority of our applications works fine when they migrated onto our
deployment that have local session enabled by default. However, explaining the
subtle difference between local and global session to users is bit tricky. So I
think for general use, local session can be disabled by default.
I agree that it will be nice to have an explicit interface to request for
global or local session. We didn't have immediate need to add this because the
current workload is sufficient and doesn't impact performance that much. The
current mechanism also backward compatible with older clients.
bq. The timeouts in the tests are too low in my experience. Use
org.apache.zookeeper.test.ClientBase.CONNECTION_TIMEOUT unless there's some
reason not to? (some of the hardware we run testing on is virtualized, can make
things very slow)
We can increase that
bq. The change to watchertest - move this to it's own jira. We can can get that
reviewed/committed quickly. Likely we need this for more than just trunk.
Someone told me that there is a flag to disable random test order in junit.
Anyway, I can move that into a separate jira.
> Add support for local sessions
> ------------------------------
>
> Key: ZOOKEEPER-1147
> URL: https://issues.apache.org/jira/browse/ZOOKEEPER-1147
> Project: ZooKeeper
> Issue Type: Improvement
> Components: server
> Affects Versions: 3.3.3
> Reporter: Vishal Kathuria
> Assignee: Thawan Kooburat
> Labels: api-change, scaling
> Fix For: 3.5.0
>
> Attachments: ZOOKEEPER-1147.patch
>
> Original Estimate: 840h
> Remaining Estimate: 840h
>
> This improvement is in the bucket of making ZooKeeper work at a large scale.
> We are planning on having about a 1 million clients connect to a ZooKeeper
> ensemble through a set of 50-100 observers. Majority of these clients are
> read only - ie they do not do any updates or create ephemeral nodes.
> In ZooKeeper today, the client creates a session and the session creation is
> handled like any other update. In the above use case, the session create/drop
> workload can easily overwhelm an ensemble. The following is a proposal for a
> "local session", to support a larger number of connections.
> 1. The idea is to introduce a new type of session - "local" session. A
> "local" session doesn't have a full functionality of a normal session.
> 2. Local sessions cannot create ephemeral nodes.
> 3. Once a local session is lost, you cannot re-establish it using the
> session-id/password. The session and its watches are gone for good.
> 4. When a local session connects, the session info is only maintained
> on the zookeeper server (in this case, an observer) that it is connected to.
> The leader is not aware of the creation of such a session and there is no
> state written to disk.
> 5. The pings and expiration is handled by the server that the session
> is connected to.
> With the above changes, we can make ZooKeeper scale to a much larger number
> of clients without making the core ensemble a bottleneck.
> In terms of API, there are two options that are being considered
> 1. Let the client specify at the connect time which kind of session do they
> want.
> 2. All sessions connect as local sessions and automatically get promoted to
> global sessions when they do an operation that requires a global session
> (e.g. creating an ephemeral node)
> Chubby took the approach of lazily promoting all sessions to global, but I
> don't think that would work in our case, where we want to keep sessions which
> never create ephemeral nodes as always local. Option 2 would make it more
> broadly usable but option 1 would be easier to implement.
> We are thinking of implementing option 1 as the first cut. There would be a
> client flag, IsLocalSession (much like the current readOnly flag) that would
> be used to determine whether to create a local session or a global session.
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira