the command to create a server is named "create-client" #760

Closed
opened 2009-07-14 14:09:01 +00:00 by zooko · 3 comments

I just had to explain to someone on the phone that the way to create a server is to run the command 'create-client'.

Maybe we should rename that command to 'create-node'? It is used for creating clients, storage servers, and web gateways, but not for creating introducers. Alternately I suppose we could split it into several commands: 'create-client', 'create-storage-server', 'create-web-gateway'?

I just had to explain to someone on the phone that the way to create a server is to run the command 'create-client'. Maybe we should rename that command to 'create-node'? It is used for creating clients, storage servers, and web gateways, but not for creating introducers. Alternately I suppose we could split it into several commands: 'create-client', 'create-storage-server', 'create-web-gateway'?
zooko added the
code-nodeadmin
major
defect
1.4.1
labels 2009-07-14 14:09:01 +00:00
zooko added this to the undecided milestone 2009-07-14 14:09:01 +00:00

My plan was to rename it 'create', and then add some options to specify which services you want the new node to provide. Since we want to do away with the Introducer eventually, I plan to retain 'create-introducer' as a separate command (rather than add 'tahoe create --introducer' and then get rid of it again later). The default node will have client functionality (i.e. the ability to upload and download files), a webapi server, and maybe storage functionality (I forget if we currently default to --with-storage or --no-storage).

But yeah, 'create-node' has the benefits of

  • being longer, since creating a new client/server node is an infrequent operation and thus, according to Zipf's Law, deserves a longer name
  • being harder to interpret as intended for creating other things, like directories, or files

I'm always on the fence as to what word to use for this client node thingy of ours. In a distributed-system sense, "node" is the right word: it's just one node out of many. If you think of things in asymmetric terms and really want to emphasize the difference between "clients" and "servers", then the node you're creating might have one or both features: sometimes you are creating a client-only node, sometimes a server-only node, and (more commonly) you are creating something that can do both. "node" has the bad quality of also being the most convenient term for elements of the file/directory DAG structure, but there we usually lean towards the longer terms "filenode" and "dirnode" (and only use the unqualified term when we need a plural: "nodes" instead of "filenodes/dirnodes" or "file/directory nodes").

So, I don't know what's the best term for the "instance of the Tahoe program (with working directory and saved state and a persistent nodeid) that you're creating for eventual launch with 'tahoe start'" thingy which would serve as the direct object in "tahoe create-XYZ".

My plan was to rename it 'create', and then add some options to specify which services you want the new node to provide. Since we want to do away with the Introducer eventually, I plan to retain 'create-introducer' as a separate command (rather than add 'tahoe create --introducer' and then get rid of it again later). The default node will have client functionality (i.e. the ability to upload and download files), a webapi server, and maybe storage functionality (I forget if we currently default to --with-storage or --no-storage). But yeah, 'create-node' has the benefits of * being longer, since creating a new client/server node is an infrequent operation and thus, according to Zipf's Law, deserves a longer name * being harder to interpret as intended for creating other things, like directories, or files I'm always on the fence as to what word to use for this client node thingy of ours. In a distributed-system sense, "node" is the right word: it's just one node out of many. If you think of things in asymmetric terms and really want to emphasize the difference between "clients" and "servers", then the node you're creating might have one or both features: sometimes you are creating a client-only node, sometimes a server-only node, and (more commonly) you are creating something that can do both. "node" has the bad quality of also being the most convenient term for elements of the file/directory DAG structure, but there we usually lean towards the longer terms "filenode" and "dirnode" (and only use the unqualified term when we need a plural: "nodes" instead of "filenodes/dirnodes" or "file/directory nodes"). So, I don't know what's the best term for the "instance of the Tahoe program (with working directory and saved state and a persistent nodeid) that you're creating for eventual launch with 'tahoe start'" thingy which would serve as the direct object in "tahoe create-XYZ".
davidsarah commented 2010-01-16 07:48:30 +00:00
Owner

Attachment create-node-darcspatch.txt (53361 bytes) added

Add create-node CLI command, and make create-client equivalent to create-node --no-storage (fixes #760)

**Attachment** create-node-darcspatch.txt (53361 bytes) added Add create-node CLI command, and make create-client equivalent to create-node --no-storage (fixes #760)
Author

Looks good! Thank you. Applied as changeset:87f1bae7fe715da1.

Looks good! Thank you. Applied as changeset:87f1bae7fe715da1.
zooko added the
fixed
label 2010-01-26 04:36:06 +00:00
zooko closed this issue 2010-01-26 04:36:06 +00:00
zooko modified the milestone from undecided to 1.6.0 2010-01-26 15:04:53 +00:00
Sign in to join this conversation.
No Milestone
No Assignees
3 Participants
Notifications
Due Date
The due date is invalid or out of range. Please use the format 'yyyy-mm-dd'.

No due date set.

Reference: tahoe-lafs/trac-2024-07-25#760
No description provided.