Wednesday, March 25, 2015
Friday, March 20, 2015
python why List and Dictionaries are automatically global?
>>> #changing a list entry is like calling a member function on the list.
... #For example a[3]=100 is Equal to a.__setitem__(3,100)
...
>>> #Without global, an assignment creates a new local.
...
>>> #In Python, if you do not assign to a variable inside a function it
... #will look for that variable in more global scopes until it finds it.
...
>>> a = range(5)
>>> def mutate(a):
... a[3] = 100
...
>>> mutate(a)
>>> print a[3]
100
>>>
>>>
>>>
>>> a = range(5)
>>> def mutate(b):
... a[3] = 100
... #Equal to a.__setitem__(3,100)
...
>>> mutate(a)
>>> print a[3]
100
>>>
>>>
>>>
>>> a = range(5)
>>> def mutate(b):
... b[3] = 100
...
>>> mutate(a)
>>> print a[3]
100
Wednesday, March 18, 2015
how to cassandra Convert hex byte values into a human readable format
1)
Open cassandra cli
#cassandra-cli
[..] help;
[..] show keyspaces;
[..] use config_db_uuid; <== select a keyspace/database
[..] List obj_uuid_table; <== Reading Rows and Columns of a table
* Cassandra stores all data internally as hex byte arrays by default. If you do not specify a default row key validation class, column comparator and column validation class when you define the column family, Cassandra CLI will expect input data for row keys, column names, and column values to be in hex format (and data will be returned in hex format).
http://www.datastax.com/docs/1.1/dml/using_cli
ASSUME obj_uuid_table KEYS AS utf8;
ASSUME obj_uuid_table COMPARATOR AS utf8;
ASSUME obj_uuid_table VALIDATOR AS utf8;
OR
ASSUME obj_uuid_table KEYS AS ascii;
ASSUME obj_uuid_table COMPARATOR AS ascii;
ASSUME obj_uuid_table VALIDATOR AS ascii;
[..]List obj_uuid_table <== Reading Rows and Columns of a table
2)
Reset
ASSUME obj_uuid_table KEYS AS bytes;
ASSUME obj_uuid_table COMPARATOR AS bytes;
ASSUME obj_uuid_table VALIDATOR AS bytes;
Open cassandra cli
#cassandra-cli
[..] help;
[..] show keyspaces;
[..] use config_db_uuid; <== select a keyspace/database
[..] List obj_uuid_table; <== Reading Rows and Columns of a table
* Cassandra stores all data internally as hex byte arrays by default. If you do not specify a default row key validation class, column comparator and column validation class when you define the column family, Cassandra CLI will expect input data for row keys, column names, and column values to be in hex format (and data will be returned in hex format).
http://www.datastax.com/docs/1.1/dml/using_cli
ASSUME obj_uuid_table KEYS AS utf8;
ASSUME obj_uuid_table COMPARATOR AS utf8;
ASSUME obj_uuid_table VALIDATOR AS utf8;
OR
ASSUME obj_uuid_table KEYS AS ascii;
ASSUME obj_uuid_table COMPARATOR AS ascii;
ASSUME obj_uuid_table VALIDATOR AS ascii;
[..]List obj_uuid_table <== Reading Rows and Columns of a table
2)
Reset
ASSUME obj_uuid_table KEYS AS bytes;
ASSUME obj_uuid_table COMPARATOR AS bytes;
ASSUME obj_uuid_table VALIDATOR AS bytes;
Getting Started Using the Cassandra CLI
1)
Open cassandra cli
#cassandra-cli
[..] help;
[..] show keyspaces;
[..] show schema
[..] use config_db_uuid: <== select a keyspace/database
[..]List obj_uuid_table <== Reading Rows and Columns of a table
* Cassandra stores all data internally as hex byte arrays by default. If you do not specify a default row key validation class, column comparator and column validation class when you define the column family, Cassandra CLI will expect input data for row keys, column names, and column values to be in hex format (and data will be returned in hex format).
http://www.datastax.com/docs/1.1/dml/using_cli
2)
Query from table with id
[..] get obj_uuid_table[utf8('d123ad89-f047-40ee-8878-4b9b05dfa513')]; <=== passing id of ipam in utf8()
=> (name=66715f6e616d65, value=["default-domain", "admin", "ipam34"], timestamp=1426111375529317)
=> (name=706172656e743a70726f6a6563743a35663037653331622d643961382d346539392d613963642d663039643161663164623231, value=null, timestamp=1426111375529098)
=> (name=706172656e745f74797065, value="project", timestamp=1426111375529317)
=> (name=70726f703a646973706c61795f6e616d65, value="ipam34", timestamp=1426111375529289)
=> (name=70726f703a69645f7065726d73, value={"enable": true, "uuid": {"uuid_mslong": 15070079586065137902, "uuid_lslong": 9833692915554034963}, "creator": null, "created": "2015-03-11T22:02:55.529187", "user_visible": true, "last_modified": "2015-03-11T22:02:55.529187", "permissions": {"owner": "cloud-admin", "owner_access": 7, "other_access": 7, "group": "admin", "group_access": 7}, "description": null}, timestamp=1426111375529239)
=> (name=70726f703a6e6574776f726b5f6970616d5f6d676d74, value={"ipam_dns_method": "default-dns-server", "ipam_dns_server": {"tenant_dns_server_address": {}, "virtual_dns_server_name": null}}, timestamp=1426111375529153)
=> (name=74797065, value="network_ipam", timestamp=1426111375529317)
Returned 7 results.
Elapsed time: 20 msec(s).
[..]
OR
[..]ASSUME obj_uuid_table KEYS AS utf8
[..]get obj_uuid_table['d123ad89-f047-40ee-8878-4b9b05dfa513'];
3)
Convert hex values into a human-readable format
ASSUME obj_uuid_table KEYS AS utf8;
ASSUME obj_uuid_table COMPARATOR AS utf8;
ASSUME obj_uuid_table VALIDATOR AS utf8;
OR
ASSUME obj_uuid_table KEYS AS ascii;
ASSUME obj_uuid_table COMPARATOR AS ascii;
ASSUME obj_uuid_table VALIDATOR AS ascii;
[..]List obj_uuid_table <== Reading Rows and Columns of a table
Open cassandra cli
#cassandra-cli
[..] help;
[..] show keyspaces;
[..] show schema
[..] use config_db_uuid: <== select a keyspace/database
[..]List obj_uuid_table <== Reading Rows and Columns of a table
* Cassandra stores all data internally as hex byte arrays by default. If you do not specify a default row key validation class, column comparator and column validation class when you define the column family, Cassandra CLI will expect input data for row keys, column names, and column values to be in hex format (and data will be returned in hex format).
http://www.datastax.com/docs/1.1/dml/using_cli
2)
Query from table with id
[..] get obj_uuid_table[utf8('d123ad89-f047-40ee-8878-4b9b05dfa513')]; <=== passing id of ipam in utf8()
=> (name=66715f6e616d65, value=["default-domain", "admin", "ipam34"], timestamp=1426111375529317)
=> (name=706172656e743a70726f6a6563743a35663037653331622d643961382d346539392d613963642d663039643161663164623231, value=null, timestamp=1426111375529098)
=> (name=706172656e745f74797065, value="project", timestamp=1426111375529317)
=> (name=70726f703a646973706c61795f6e616d65, value="ipam34", timestamp=1426111375529289)
=> (name=70726f703a69645f7065726d73, value={"enable": true, "uuid": {"uuid_mslong": 15070079586065137902, "uuid_lslong": 9833692915554034963}, "creator": null, "created": "2015-03-11T22:02:55.529187", "user_visible": true, "last_modified": "2015-03-11T22:02:55.529187", "permissions": {"owner": "cloud-admin", "owner_access": 7, "other_access": 7, "group": "admin", "group_access": 7}, "description": null}, timestamp=1426111375529239)
=> (name=70726f703a6e6574776f726b5f6970616d5f6d676d74, value={"ipam_dns_method": "default-dns-server", "ipam_dns_server": {"tenant_dns_server_address": {}, "virtual_dns_server_name": null}}, timestamp=1426111375529153)
=> (name=74797065, value="network_ipam", timestamp=1426111375529317)
Returned 7 results.
Elapsed time: 20 msec(s).
[..]
OR
[..]ASSUME obj_uuid_table KEYS AS utf8
[..]get obj_uuid_table['d123ad89-f047-40ee-8878-4b9b05dfa513'];
3)
Convert hex values into a human-readable format
ASSUME obj_uuid_table KEYS AS utf8;
ASSUME obj_uuid_table COMPARATOR AS utf8;
ASSUME obj_uuid_table VALIDATOR AS utf8;
OR
ASSUME obj_uuid_table KEYS AS ascii;
ASSUME obj_uuid_table COMPARATOR AS ascii;
ASSUME obj_uuid_table VALIDATOR AS ascii;
[..]List obj_uuid_table <== Reading Rows and Columns of a table
Tuesday, March 17, 2015
python StringIO usages
http://www.dotnetperls.com/stringio
http://stackoverflow.com/questions/7996479/what-is-stringio-in-python-used-for-in-reality
1)
* To unit-test a script that does a lot of printing, by redirecting sys.stdout to a StringIO instance for easy analysis;
* To create a guaranteed well-formed XML document (a custom API request) using ElementTree and then write it for sending via a HTTP connection.
* Not that you need StringIO often, but sometimes it's pretty useful.
2)
* StringIO gives you file-like access to strings, so you can use an existing module that deals with a file and change almost nothing and make it work with strings.
* For example, say you have a logger that writes things to a file and you want to instead send the log output over the network. You can read the file and write its contents to the network, or you can write the log to a StringIO object and ship it off to its network destination without touching the filesystem. StringIO makes it easy to do it the first way then switch to the second way.
3)
In cases where you want a file-like object that ACTS like a file, but is writing to an in-memory string buffer: StringIO is the tool. If you're building large strings, such as plain-text documents, and doing a lot of string concatenation, you might find it easier to just use StringIO instead of a bunch of mystr += 'more stuff\n' type of operations.
How to Apache zookeeper configure session timeout
1)
Find location of zkServer.sh script
#find / -name zkServer.sh
OR
#locate zkServer.sh
2)
#cd cd /opt/stack/contrail/third_party/zookeeper-3.4.6/bin/
saju@ubuntu:/opt/stack/contrail/third_party/zookeeper-3.4.6/bin$ ls
README.txt zkCleanup.sh zkCli.cmd zkCli.sh zkEnv.cmd zkEnv.sh zkServer.cmd zkServer.sh
3)
Find zoo.cfg
saju@ubuntu:/opt/stack/contrail/third_party/zookeeper-3.4.6/bin$ ./zkServer.sh --help
JMX enabled by default
Using config: /opt/stack/contrail/third_party/zookeeper-3.4.6/bin/../conf/zoo.cfg
Usage: ./zkServer.sh {start|start-foreground|stop|restart|status|upgrade|print-cmd}
4)
Edit "zoo.cfg" and change session timeout
saju@ubuntu:/opt/stack/contrail/third_party/zookeeper-3.4.6/bin$ sudo vim ../conf/zoo.cfg
# The number of milliseconds of each tick
tickTime=20000000
# The number of ticks that the initial
# synchronization phase can take
initLimit=10
# The number of ticks that can pass between
# sending a request and getting an acknowledgement
syncLimit=5
# the directory where the snapshot is stored.
# do not use /tmp for storage, /tmp here is just
# example sakes.
dataDir=/tmp/zookeeper
# the port at which the clients will connect
clientPort=2181
# the maximum number of client connections.
# increase this if you need to handle more clients
#maxClientCnxns=60
#
# Be sure to read the maintenance section of the
# administrator guide before turning on autopurge.
#
# http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance
#
# The number of snapshots to retain in dataDir
#autopurge.snapRetainCount=3
# Purge task interval in hours
# Set to "0" to disable auto purge feature
#autopurge.purgeInterval=1
5)
Stop zookeeper
#cd /opt/stack/contrail/third_party/zookeeper-3.4.6; ./bin/zkServer.sh stop & echo $! >/home/saju/contrail-installer/status/contrail/zk.pid; fg || echo "zk failed to start" | tee "/home/saju/contrail-installer/status/contrail/zk.failure
6)
Start zookeeper
#cd /opt/stack/contrail/third_party/zookeeper-3.4.6; ./bin/zkServer.sh start & echo $! >/home/saju/contrail-installer/status/contrail/zk.pid; fg || echo "zk failed to start" | tee "/home/saju/contrail-installer/status/contrail/zk.failure
Find location of zkServer.sh script
#find / -name zkServer.sh
OR
#locate zkServer.sh
2)
#cd cd /opt/stack/contrail/third_party/zookeeper-3.4.6/bin/
saju@ubuntu:/opt/stack/contrail/third_party/zookeeper-3.4.6/bin$ ls
README.txt zkCleanup.sh zkCli.cmd zkCli.sh zkEnv.cmd zkEnv.sh zkServer.cmd zkServer.sh
3)
Find zoo.cfg
saju@ubuntu:/opt/stack/contrail/third_party/zookeeper-3.4.6/bin$ ./zkServer.sh --help
JMX enabled by default
Using config: /opt/stack/contrail/third_party/zookeeper-3.4.6/bin/../conf/zoo.cfg
Usage: ./zkServer.sh {start|start-foreground|stop|restart|status|upgrade|print-cmd}
4)
Edit "zoo.cfg" and change session timeout
saju@ubuntu:/opt/stack/contrail/third_party/zookeeper-3.4.6/bin$ sudo vim ../conf/zoo.cfg
# The number of milliseconds of each tick
tickTime=20000000
# The number of ticks that the initial
# synchronization phase can take
initLimit=10
# The number of ticks that can pass between
# sending a request and getting an acknowledgement
syncLimit=5
# the directory where the snapshot is stored.
# do not use /tmp for storage, /tmp here is just
# example sakes.
dataDir=/tmp/zookeeper
# the port at which the clients will connect
clientPort=2181
# the maximum number of client connections.
# increase this if you need to handle more clients
#maxClientCnxns=60
#
# Be sure to read the maintenance section of the
# administrator guide before turning on autopurge.
#
# http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance
#
# The number of snapshots to retain in dataDir
#autopurge.snapRetainCount=3
# Purge task interval in hours
# Set to "0" to disable auto purge feature
#autopurge.purgeInterval=1
5)
Stop zookeeper
#cd /opt/stack/contrail/third_party/zookeeper-3.4.6; ./bin/zkServer.sh stop & echo $! >/home/saju/contrail-installer/status/contrail/zk.pid; fg || echo "zk failed to start" | tee "/home/saju/contrail-installer/status/contrail/zk.failure
6)
Start zookeeper
#cd /opt/stack/contrail/third_party/zookeeper-3.4.6; ./bin/zkServer.sh start & echo $! >/home/saju/contrail-installer/status/contrail/zk.pid; fg || echo "zk failed to start" | tee "/home/saju/contrail-installer/status/contrail/zk.failure
Monday, March 16, 2015
How to increment a numeric string '0000000001' in python?
>>>
>>> for x in range(1, 20):
... "%(#)010d" % {'#': x}
...
'0000000001'
'0000000002'
'0000000003'
'0000000004'
'0000000005'
'0000000006'
'0000000007'
'0000000008'
'0000000009'
'0000000010'
'0000000011'
'0000000012'
'0000000013'
'0000000014'
'0000000015'
'0000000016'
'0000000017'
'0000000018'
'0000000019'
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>> for x in range(1, 20):
... "%(replace)010d" % {'replace': x}
...
'0000000001'
'0000000002'
'0000000003'
'0000000004'
'0000000005'
'0000000006'
'0000000007'
'0000000008'
'0000000009'
'0000000010'
'0000000011'
'0000000012'
'0000000013'
'0000000014'
'0000000015'
'0000000016'
'0000000017'
'0000000018'
'0000000019'
>>>
>>>
http://stackoverflow.com/questions/23270503/how-to-increment-a-numeric-string-0000000001-in-python
>>> for x in range(1, 20):
... "%(#)010d" % {'#': x}
...
'0000000001'
'0000000002'
'0000000003'
'0000000004'
'0000000005'
'0000000006'
'0000000007'
'0000000008'
'0000000009'
'0000000010'
'0000000011'
'0000000012'
'0000000013'
'0000000014'
'0000000015'
'0000000016'
'0000000017'
'0000000018'
'0000000019'
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>> for x in range(1, 20):
... "%(replace)010d" % {'replace': x}
...
'0000000001'
'0000000002'
'0000000003'
'0000000004'
'0000000005'
'0000000006'
'0000000007'
'0000000008'
'0000000009'
'0000000010'
'0000000011'
'0000000012'
'0000000013'
'0000000014'
'0000000015'
'0000000016'
'0000000017'
'0000000018'
'0000000019'
>>>
>>>
http://stackoverflow.com/questions/23270503/how-to-increment-a-numeric-string-0000000001-in-python
Sunday, March 15, 2015
Tutorial Cassandra Query Language (CQL) commands using cqlsh utility
The Cassandra installation includes the cqlsh utility, a python-based command line client
for executing Cassandra Query Language (CQL) commands. The cqlsh command is used on the
Linux or Windows command line to start the cqlsh utility.
You can use cqlsh to execute CQL commands interactively. cqlsh supports tab completion. http://www.datastax.com/documentation/cql/3.1/cql/cql_reference/cqlsh.html
#cqlsh
cqlsh> help
cqlsh> help DESCRIBE
cqlsh> DESCRIBE KEYSPACES;
cqlsh> DESCRIBE KEYSPACE [mykeyspce];
cqlsh> DESCRIBE TABLES <== Show all the tables in all keyspaces
cqlsh> help USE
cqlsh> USE[name]; <== Goto keyspace/database
cqlsh:> DESCRIBE TABLES <== Show all the tables in selected keyspace
cqlsh:> DESCRIBE TABLE [tablename]; <== Describe the table in the selected keyspace.
cqlsh:> help SELECT
1)
Delete Keyspace
cqlsh> DROP KEYSPACE config_db_uuid;
2)
a)
cqlsh> DESCRIBE TABLES
Keyspace "DISCOVERY_SERVER"
---------------------------
discovery
b)
cqlsh> DESCRIBE table DISCOVERY_SERVER.discovery
CREATE TABLE discovery (
key blob,
column1 ascii,
column2 text,
column3 text,
value ascii,
PRIMARY KEY (key, column1, column2, column3)
) WITH COMPACT STORAGE AND
bloom_filter_fp_chance=0.010000 AND
caching='KEYS_ONLY' AND
comment='' AND
dclocal_read_repair_chance=0.000000 AND
gc_grace_seconds=0 AND
read_repair_chance=0.100000 AND
replicate_on_write='true' AND
populate_io_cache_on_flush='false' AND
compaction={'class': 'SizeTieredCompactionStrategy'} AND
compression={'sstable_compression': 'SnappyCompressor'};
cqlsh>
c)
cqlsh> use "DISCOVERY_SERVER";
cqlsh:DISCOVERY_SERVER>
* Imp, use double quotes
d)
cqlsh:DISCOVERY_SERVER> select * from discovery limit 1;
key | column1 | column2 | column3 | value
--------------------+---------+------------------------+----------------+--------------------------------------------------------------------------------
0x4f70536572766572 | client | vpc-cfg1:ContrailWebUI | $client-entry$ | {"instances": 20, "client_type": "ContrailWebUI", "remote": "192.168.100.185"}
e)
Get all services/publisher
cqlsh:DISCOVERY_SERVER> select * from discovery where column1 = 'service' ALLOW FILTERING;
f)
Get all clients
cqlsh:DISCOVERY_SERVER> select * from discovery where column1 = 'client' ALLOW FILTERING;
g)
Get all subscribers
cqlsh:DISCOVERY_SERVER> select * from discovery where column1 = 'subscriber' ALLOW FILTERING;
You can use cqlsh to execute CQL commands interactively. cqlsh supports tab completion. http://www.datastax.com/documentation/cql/3.1/cql/cql_reference/cqlsh.html
#cqlsh
cqlsh> help
cqlsh> help DESCRIBE
cqlsh> DESCRIBE KEYSPACES;
cqlsh> DESCRIBE KEYSPACE [mykeyspce];
cqlsh> DESCRIBE TABLES <== Show all the tables in all keyspaces
cqlsh> help USE
cqlsh> USE
cqlsh:
cqlsh:
cqlsh:
1)
Delete Keyspace
cqlsh> DROP KEYSPACE config_db_uuid;
2)
a)
cqlsh> DESCRIBE TABLES
Keyspace "DISCOVERY_SERVER"
---------------------------
discovery
b)
cqlsh> DESCRIBE table DISCOVERY_SERVER.discovery
CREATE TABLE discovery (
key blob,
column1 ascii,
column2 text,
column3 text,
value ascii,
PRIMARY KEY (key, column1, column2, column3)
) WITH COMPACT STORAGE AND
bloom_filter_fp_chance=0.010000 AND
caching='KEYS_ONLY' AND
comment='' AND
dclocal_read_repair_chance=0.000000 AND
gc_grace_seconds=0 AND
read_repair_chance=0.100000 AND
replicate_on_write='true' AND
populate_io_cache_on_flush='false' AND
compaction={'class': 'SizeTieredCompactionStrategy'} AND
compression={'sstable_compression': 'SnappyCompressor'};
cqlsh>
c)
cqlsh> use "DISCOVERY_SERVER";
cqlsh:DISCOVERY_SERVER>
* Imp, use double quotes
d)
cqlsh:DISCOVERY_SERVER> select * from discovery limit 1;
key | column1 | column2 | column3 | value
--------------------+---------+------------------------+----------------+--------------------------------------------------------------------------------
0x4f70536572766572 | client | vpc-cfg1:ContrailWebUI | $client-entry$ | {"instances": 20, "client_type": "ContrailWebUI", "remote": "192.168.100.185"}
e)
Get all services/publisher
cqlsh:DISCOVERY_SERVER> select * from discovery where column1 = 'service' ALLOW FILTERING;
f)
Get all clients
cqlsh:DISCOVERY_SERVER> select * from discovery where column1 = 'client' ALLOW FILTERING;
g)
Get all subscribers
cqlsh:DISCOVERY_SERVER> select * from discovery where column1 = 'subscriber' ALLOW FILTERING;
OpenContrail Uses of ZooKeeper
In OpenContrail ZooKeeper is currently used for
1) master-election
* For schema-transformer: https://github.com/Juniper/contrail-controller/blob/master/src/config/schema-transformer/to_bgp.py#L3713
* For device-manager: https://github.com/Juniper/contrail-controller/blob/master/src/config/device-manager/device_manager/device_manager.py#L469
2) index-allocation
*IndexAllocator: https://github.com/Juniper/contrail-controller/blob/master/src/config/common/zkclient.py#L22
* In schema-transformer: https://github.com/Juniper/contrail-controller/blob/master/src/config/schema-transformer/to_bgp.py#L2526
* index-allocation is used for things like (virtual-network id for every VN, security-group id for every SG).There is a vn-id for every VN. this vn-id is sent across in bgp messages between control-node.
3) Arbitration reasons
* To convert fq-name to uuid when uuid not specified in requests.
* If there is 2 concurrent requests, api-server allocates/reserves a uuid in zk, that way only one create will succeed.
* create_fq_name_to_uuid_mapping: https://github.com/Juniper/contrail-controller/blob/master/src/config/api-server/vnc_cfg_ifmap.py#L1129
* ZookeeperClient: https://github.com/Juniper/contrail-controller/blob/master/src/config/common/zkclient.py#L181
1) master-election
* For schema-transformer: https://github.com/Juniper/contrail-controller/blob/master/src/config/schema-transformer/to_bgp.py#L3713
* For device-manager: https://github.com/Juniper/contrail-controller/blob/master/src/config/device-manager/device_manager/device_manager.py#L469
2) index-allocation
*IndexAllocator: https://github.com/Juniper/contrail-controller/blob/master/src/config/common/zkclient.py#L22
* In schema-transformer: https://github.com/Juniper/contrail-controller/blob/master/src/config/schema-transformer/to_bgp.py#L2526
* index-allocation is used for things like (virtual-network id for every VN, security-group id for every SG).There is a vn-id for every VN. this vn-id is sent across in bgp messages between control-node.
3) Arbitration reasons
* To convert fq-name to uuid when uuid not specified in requests.
* If there is 2 concurrent requests, api-server allocates/reserves a uuid in zk, that way only one create will succeed.
* create_fq_name_to_uuid_mapping: https://github.com/Juniper/contrail-controller/blob/master/src/config/api-server/vnc_cfg_ifmap.py#L1129
* ZookeeperClient: https://github.com/Juniper/contrail-controller/blob/master/src/config/common/zkclient.py#L181
How to use Apache ZooKeeper zkCli Command Line Interface
a)
Find zookeeper Cli
#locate zkCli
b)
Find process ID of zookeeper
#sudo ps -aux | grep zoo
c)
Find port of zookeeper using process ID
#sudo netstat -tuplen | grep 3876
tcp6 0 0 :::2181 :::* LISTEN 1000 14046 3876/java
tcp6 0 0 :::33040 :::* LISTEN 1000 13626 3876/java
* Two instance (port 2181 and 33040) of zookeeper service are running
d)
Connect to zookeeper server
#cd /opt/stack/contrail/third_party/zookeeper-3.4.6/bin/
#./zkCli.sh -server 192.168.56.102:2181
* http://zookeeper.apache.org/doc/r3.3.3/zookeeperStarted.html
e)
Get zookeeper Cli commands
[zk: 192.168.56.102:2181(CONNECTED) 0] help
f)
List path
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /[svc-monitor, id, schema-transformer, fq-name-to-uuid, api-server, zookeeper]
* schema-transformer creates "/id"
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /fq-name-to-uuid
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /id
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /schema-transformer
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /svc-monitor
g)
Get data from path
* Get ID of default IPAM "default-network-ipam" in the "default-project" project.
[zk: 192.168.56.102:2181(CONNECTED) 36] get /fq-name-to-uuid/network_ipam:default-domain:default-project:default-network-ipam
0bee2fa4-766d-438f-9991-0fe4b34577b8
* Get ID of IPAM "ipam333" in the "admin" project.
[zk: 192.168.56.102:2181(CONNECTED) 37] get /fq-name-to-uuid/network_ipam:default-domain:admin:ipam333
1d54fc41-8697-4747-ab1f-f85ad53ac59d
h)
Set data
* Set ID of IPAM "ipam333" in the "admin" project.
[zk: 192.168.56.102:2181(CONNECTED) 44] set /fq-name-to-uuid/network_ipam:default-domain:admin:ipam333 1d54fc41-8697-4747-ab1f-f85ad53ac599
i)
Delete Path
i1)
[zk: localhost:2181(CONNECTED) 12] get /fq-name-to-uuid/global_system_config:default-global-system-config
a9f53855-477f-4509-bd40-9297470b7a0b
cZxid = 0xa
ctime = Thu Oct 15 05:42:46 UTC 2015
mZxid = 0xa
mtime = Thu Oct 15 05:42:46 UTC 2015
pZxid = 0xa
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 36
numChildren = 0
i2)
[zk: localhost:2181(CONNECTED) 12] rmr /fq-name-to-uuid/global_system_config:default-global-system-config
i3)
[zk: localhost:2181(CONNECTED) 13] get /fq-name-to-uuid/global_system_config:default-global-system-config
Node does not exist: /fq-name-to-uuid/global_system_config:default-global-system-config
Find zookeeper Cli
#locate zkCli
b)
Find process ID of zookeeper
#sudo ps -aux | grep zoo
c)
Find port of zookeeper using process ID
#sudo netstat -tuplen | grep 3876
tcp6 0 0 :::2181 :::* LISTEN 1000 14046 3876/java
tcp6 0 0 :::33040 :::* LISTEN 1000 13626 3876/java
* Two instance (port 2181 and 33040) of zookeeper service are running
d)
Connect to zookeeper server
#cd /opt/stack/contrail/third_party/zookeeper-3.4.6/bin/
#./zkCli.sh -server 192.168.56.102:2181
* http://zookeeper.apache.org/doc/r3.3.3/zookeeperStarted.html
e)
Get zookeeper Cli commands
[zk: 192.168.56.102:2181(CONNECTED) 0] help
f)
List path
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /[svc-monitor, id, schema-transformer, fq-name-to-uuid, api-server, zookeeper]
* schema-transformer creates "/id"
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /fq-name-to-uuid
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /id
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /schema-transformer
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /svc-monitor
g)
Get data from path
* Get ID of default IPAM "default-network-ipam" in the "default-project" project.
[zk: 192.168.56.102:2181(CONNECTED) 36] get /fq-name-to-uuid/network_ipam:default-domain:default-project:default-network-ipam
0bee2fa4-766d-438f-9991-0fe4b34577b8
* Get ID of IPAM "ipam333" in the "admin" project.
[zk: 192.168.56.102:2181(CONNECTED) 37] get /fq-name-to-uuid/network_ipam:default-domain:admin:ipam333
1d54fc41-8697-4747-ab1f-f85ad53ac59d
h)
Set data
* Set ID of IPAM "ipam333" in the "admin" project.
[zk: 192.168.56.102:2181(CONNECTED) 44] set /fq-name-to-uuid/network_ipam:default-domain:admin:ipam333 1d54fc41-8697-4747-ab1f-f85ad53ac599
i)
Delete Path
i1)
[zk: localhost:2181(CONNECTED) 12] get /fq-name-to-uuid/global_system_config:default-global-system-config
a9f53855-477f-4509-bd40-9297470b7a0b
cZxid = 0xa
ctime = Thu Oct 15 05:42:46 UTC 2015
mZxid = 0xa
mtime = Thu Oct 15 05:42:46 UTC 2015
pZxid = 0xa
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 36
numChildren = 0
i2)
[zk: localhost:2181(CONNECTED) 12] rmr /fq-name-to-uuid/global_system_config:default-global-system-config
i3)
[zk: localhost:2181(CONNECTED) 13] get /fq-name-to-uuid/global_system_config:default-global-system-config
Node does not exist: /fq-name-to-uuid/global_system_config:default-global-system-config
Thursday, March 12, 2015
IF-MAP Visualize the content of a MAP Server
How to IF-MAP Visualize the content of a MAP Server
1)
Install Java
#sudo apt-add-repository ppa:webupd8team/java
#sudo apt-get update
#sudo apt-get install oracle-java8-installer
#sudo apt-get install oracle-java8-set-default
#java -version
2)
Download irongui
https://github.com/trustathsh/irongui/releases
#wget https://github.com/trustathsh/irongui/releases/download/v0.4.5/irongui-0.4.5-bundle.zip
3)
Unizip
#unzip irongui-0.4.5-bundle.zip
#cd irongui-0.4.5
4)
Run
#./start.sh
5)
a)
Click on "Manage IF-MAP connections" icon and open "Manage IF-MAP connections" Window.
b)
Create duplicate of "default-irond-basicauth" connection and change following settings and Click on "Test connection" button.
Endpoint: https://192.168.56.102:8443/ <== Endpoint of MAP Server
Username: api-server
PAssword: api-server
Dump: Select it <=== Required
6)
Close "Manage IF-MAP connections" Window.
Select the new connection from left navigation and click on "Start session with current selection" button.
...Done...
1)
Install Java
#sudo apt-add-repository ppa:webupd8team/java
#sudo apt-get update
#sudo apt-get install oracle-java8-installer
#sudo apt-get install oracle-java8-set-default
#java -version
2)
Download irongui
https://github.com/trustathsh/irongui/releases
#wget https://github.com/trustathsh/irongui/releases/download/v0.4.5/irongui-0.4.5-bundle.zip
3)
Unizip
#unzip irongui-0.4.5-bundle.zip
#cd irongui-0.4.5
4)
Run
#./start.sh
5)
a)
Click on "Manage IF-MAP connections" icon and open "Manage IF-MAP connections" Window.
b)
Create duplicate of "default-irond-basicauth" connection and change following settings and Click on "Test connection" button.
Endpoint: https://192.168.56.102:8443/ <== Endpoint of MAP Server
Username: api-server
PAssword: api-server
Dump: Select it <=== Required
6)
Close "Manage IF-MAP connections" Window.
Select the new connection from left navigation and click on "Start session with current selection" button.
...Done...
Wednesday, March 11, 2015
Ubuntu Install OpenSSH Server and Enable SSH from Remote Machine
1)
Check whether SSH Server running or not
#sudo netstat -tuplen | grep 22
#sudo dpkg -L ssh
2)
Install OpenSSH Server and SSH
#sudo apt-get update
#sudo apt-get install ssh
3)
Try to SSH from remote machine
#ssh username@ip-of-machine
Check whether SSH Server running or not
#sudo netstat -tuplen | grep 22
#sudo dpkg -L ssh
2)
Install OpenSSH Server and SSH
#sudo apt-get update
#sudo apt-get install ssh
3)
Try to SSH from remote machine
#ssh username@ip-of-machine
Tuesday, March 10, 2015
How to Django Debug TransactionManagementError: Transaction managed block ended with pending COMMIT/ROLLBACK
from django.db import transaction
from saju.core.models import Agent
1)
Error Case-1
===============
@transaction.commit_manually
def f1():
print 1
try:
a=Agent.objects.filter(id=454200).all()[0]
a.contact_email="bla@blabla.com"
a.save()
raise Exception("dummy exception")
except Exception as e:
raise e
transaction.rollback()
transaction.commit()
2)
Error Case-2
===============
@transaction.commit_manually
def f1():
print 1
try:
a=Agent.objects.filter(id=454200).all()[0]
a.contact_email="bla@blabla.com"
a.save()
except Exception as e:
transaction.rollback()
raise Exception("dummy exception")
transaction.commit()
3)
Solution-1
===============
###How to see the Actual error ?
###Add a "try..final" block with "transaction.rollback()" to see the Actual error
@transaction.commit_manually
def f1():
try:
print 1
try:
a=Agent.objects.filter(id=454200).all()[0]
a.contact_email="bla@blabla.com"
a.save()
raise Exception("dummy exception")
except Exception as e:
raise e
transaction.rollback()
transaction.commit()
finally:
transaction.rollback()
4)
Solution-2
===============
###How to see the Actual error ?
###Add a "try..final" block with "transaction.rollback()" to see the Actual error
@transaction.commit_manually
def f1():
try:
print 1
try:
a=Agent.objects.filter(id=454200).all()[0]
a.contact_email="bla@blabla.com"
a.save()
except Exception as e:
transaction.rollback()
raise Exception("dummy exception")
transaction.commit()
finally:
transaction.rollback()
from saju.core.models import Agent
1)
Error Case-1
===============
@transaction.commit_manually
def f1():
print 1
try:
a=Agent.objects.filter(id=454200).all()[0]
a.contact_email="bla@blabla.com"
a.save()
raise Exception("dummy exception")
except Exception as e:
raise e
transaction.rollback()
transaction.commit()
2)
Error Case-2
===============
@transaction.commit_manually
def f1():
print 1
try:
a=Agent.objects.filter(id=454200).all()[0]
a.contact_email="bla@blabla.com"
a.save()
except Exception as e:
transaction.rollback()
raise Exception("dummy exception")
transaction.commit()
3)
Solution-1
===============
###How to see the Actual error ?
###Add a "try..final" block with "transaction.rollback()" to see the Actual error
@transaction.commit_manually
def f1():
try:
print 1
try:
a=Agent.objects.filter(id=454200).all()[0]
a.contact_email="bla@blabla.com"
a.save()
raise Exception("dummy exception")
except Exception as e:
raise e
transaction.rollback()
transaction.commit()
finally:
transaction.rollback()
4)
Solution-2
===============
###How to see the Actual error ?
###Add a "try..final" block with "transaction.rollback()" to see the Actual error
@transaction.commit_manually
def f1():
try:
print 1
try:
a=Agent.objects.filter(id=454200).all()[0]
a.contact_email="bla@blabla.com"
a.save()
except Exception as e:
transaction.rollback()
raise Exception("dummy exception")
transaction.commit()
finally:
transaction.rollback()
How to Django Aggregate with Distinct
1)
Open Django shell
#python manage.py shell
2)
>>>
>>>
>>> from django.db.models import Count
>>> from bla.core.models import Building
>>>
>>> Building.objects.filter(agent=454200).aggregate(count=Count('user'))
{'count': 29}
>>>
>>>
>>> Building.objects.filter(agent=454200).aggregate(count=Count('user', distinct=True))
{'count': 7}
>>>
>>>
>>>
>>>
>>> user_tot = 0
>>> for b in Building.objects.filter(agent=454200).all():
... if b.user:
... user_tot += 1
...
>>>
>>>
>>> user_tot
29
>>>
>>>
>>>
Open Django shell
#python manage.py shell
2)
>>>
>>>
>>> from django.db.models import Count
>>> from bla.core.models import Building
>>>
>>> Building.objects.filter(agent=454200).aggregate(count=Count('user'))
{'count': 29}
>>>
>>>
>>> Building.objects.filter(agent=454200).aggregate(count=Count('user', distinct=True))
{'count': 7}
>>>
>>>
>>>
>>>
>>> user_tot = 0
>>> for b in Building.objects.filter(agent=454200).all():
... if b.user:
... user_tot += 1
...
>>>
>>>
>>> user_tot
29
>>>
>>>
>>>
Monday, March 9, 2015
How to Get the SQL Query from Django QuerySet
1)
Open django shell
#python manage.py shell
2)
Import the model class
>>> from bla.models import Building
3)
Print the SQL query
>>> print Building.objects.all().query
OR
>>> Building.objects.all().query.__str__()
Open django shell
#python manage.py shell
2)
Import the model class
>>> from bla.models import Building
3)
Print the SQL query
>>> print Building.objects.all().query
OR
>>> Building.objects.all().query.__str__()
Friday, March 6, 2015
OpenContrail How to Check the IF-MAP Server Population
1)
Find "ifmap_view.py" script.
#locate ifmap_view.py
/usr/local/lib/python2.7/dist-packages/schema_transformer/ifmap_view.py
2)
Run "ifmap_view.py" script by passing ifmap-server-ip, ifmap-server-port, ifmap-server-username and ifmap-server-password.
#cd /usr/local/lib/python2.7/dist-packages/schema_transformer/
OR
#cd /usr/lib/python2.7/dist-packages/schema_transformer/
#sudo python ifmap_view.py 192.168.56.102 8443 api-server api-server
MAP server connection = 192.168.56.102:8443
MAP server credentials = api-server:api-server
Start node = None
Skip List = ['id-perms']
Verbose = 0
config-root = root
domain = default-domain
global-system-config = default-global-system-config
domain = default-domain
namespace = default-namespace
project = demo
security-group = default
access-control-list = ingress-access-control-list
access-control-list = egress-access-control-list
project = admin
network-ipam = ipam444
security-group = default
access-control-list = ingress-access-control-list
access-control-list = egress-access-control-list
virtual-network = nw1
access-control-list = nw1
route-target = 8000001
network-ipam = ipam444
network-policy = default-network-policy
project = default-project
interface-route-table = default-interface-route-table
network-ipam = default-network-ipam
network-policy = default-network-policy
route-table = default-route-table
virtual-network = ip-fabric
routing-instance = __default__
virtual-network = default-virtual-network
routing-instance = default-virtual-network
route-target = 8000000
virtual-network = __link_local__
routing-instance = __link_local__
service-template = analyzer-template
service-template = docker-template
service-template = nat-template
service-template = netns-snat-template
service-template = haproxy-loadbalancer-template
global-system-config = default-global-system-config
global-vrouter-config = default-global-vrouter-config
physical-router = default-physical-router
logical-interface = default-logical-interface
physical-interface = default-physical-interface
logical-interface = default-logical-interface
virtual-router = ubuntu
route-target = 8000001
route-target = 8000000
Find "ifmap_view.py" script.
#locate ifmap_view.py
/usr/local/lib/python2.7/dist-packages/schema_transformer/ifmap_view.py
2)
Run "ifmap_view.py" script by passing ifmap-server-ip, ifmap-server-port, ifmap-server-username and ifmap-server-password.
#cd /usr/local/lib/python2.7/dist-packages/schema_transformer/
OR
#cd /usr/lib/python2.7/dist-packages/schema_transformer/
#sudo python ifmap_view.py 192.168.56.102 8443 api-server api-server
MAP server connection = 192.168.56.102:8443
MAP server credentials = api-server:api-server
Start node = None
Skip List = ['id-perms']
Verbose = 0
config-root = root
domain = default-domain
global-system-config = default-global-system-config
domain = default-domain
namespace = default-namespace
project = demo
security-group = default
access-control-list = ingress-access-control-list
access-control-list = egress-access-control-list
project = admin
network-ipam = ipam444
security-group = default
access-control-list = ingress-access-control-list
access-control-list = egress-access-control-list
virtual-network = nw1
access-control-list = nw1
route-target = 8000001
network-ipam = ipam444
network-policy = default-network-policy
project = default-project
interface-route-table = default-interface-route-table
network-ipam = default-network-ipam
network-policy = default-network-policy
route-table = default-route-table
virtual-network = ip-fabric
routing-instance = __default__
virtual-network = default-virtual-network
routing-instance = default-virtual-network
route-target = 8000000
virtual-network = __link_local__
routing-instance = __link_local__
service-template = analyzer-template
service-template = docker-template
service-template = nat-template
service-template = netns-snat-template
service-template = haproxy-loadbalancer-template
global-system-config = default-global-system-config
global-vrouter-config = default-global-vrouter-config
physical-router = default-physical-router
logical-interface = default-logical-interface
physical-interface = default-physical-interface
logical-interface = default-logical-interface
virtual-router = ubuntu
route-target = 8000001
route-target = 8000000
OpenContrail ZooKeeper Client
a)
Find zookeeper Cli
#locate zkCli
b)
Find process ID of zookeeper
#sudo ps -aux | grep zoo
c)
Find port of zookeeper using process ID
#sudo netstat -tuplen | grep 3876
tcp6 0 0 :::2181 :::* LISTEN 1000 14046 3876/java
tcp6 0 0 :::33040 :::* LISTEN 1000 13626 3876/java
* Two instance (port 2181 and 33040) of zookeeper service are running
d)
Connect to zookeeper server
#cd /opt/stack/contrail/third_party/zookeeper-3.4.6/bin/
#./zkCli.sh -server 192.168.56.102:2181
* http://zookeeper.apache.org/doc/r3.3.3/zookeeperStarted.html
e)
Get zookeeper Cli commands
[zk: 192.168.56.102:2181(CONNECTED) 0] help
f)
List path
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /[svc-monitor, id, schema-transformer, fq-name-to-uuid, api-server, zookeeper]
* schema-transformer creates "/id"
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /fq-name-to-uuid
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /id
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /schema-transformer
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /svc-monitor
g)
Get data from path
* Get ID of default IPAM "default-network-ipam" in the "default-project" project.
[zk: 192.168.56.102:2181(CONNECTED) 36] get /fq-name-to-uuid/network_ipam:default-domain:default-project:default-network-ipam
0bee2fa4-766d-438f-9991-0fe4b34577b8
* Get ID of IPAM "ipam333" in the "admin" project.
[zk: 192.168.56.102:2181(CONNECTED) 37] get /fq-name-to-uuid/network_ipam:default-domain:admin:ipam333
1d54fc41-8697-4747-ab1f-f85ad53ac59d
h)
Set data
* Set ID of IPAM "ipam333" in the "admin" project.
[zk: 192.168.56.102:2181(CONNECTED) 44] set /fq-name-to-uuid/network_ipam:default-domain:admin:ipam333 1d54fc41-8697-4747-ab1f-f85ad53ac599
Find zookeeper Cli
#locate zkCli
b)
Find process ID of zookeeper
#sudo ps -aux | grep zoo
c)
Find port of zookeeper using process ID
#sudo netstat -tuplen | grep 3876
tcp6 0 0 :::2181 :::* LISTEN 1000 14046 3876/java
tcp6 0 0 :::33040 :::* LISTEN 1000 13626 3876/java
* Two instance (port 2181 and 33040) of zookeeper service are running
d)
Connect to zookeeper server
#cd /opt/stack/contrail/third_party/zookeeper-3.4.6/bin/
#./zkCli.sh -server 192.168.56.102:2181
* http://zookeeper.apache.org/doc/r3.3.3/zookeeperStarted.html
e)
Get zookeeper Cli commands
[zk: 192.168.56.102:2181(CONNECTED) 0] help
f)
List path
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /[svc-monitor, id, schema-transformer, fq-name-to-uuid, api-server, zookeeper]
* schema-transformer creates "/id"
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /fq-name-to-uuid
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /id
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /schema-transformer
[zk: 192.168.56.102:2181(CONNECTED) 13] ls /svc-monitor
g)
Get data from path
* Get ID of default IPAM "default-network-ipam" in the "default-project" project.
[zk: 192.168.56.102:2181(CONNECTED) 36] get /fq-name-to-uuid/network_ipam:default-domain:default-project:default-network-ipam
0bee2fa4-766d-438f-9991-0fe4b34577b8
* Get ID of IPAM "ipam333" in the "admin" project.
[zk: 192.168.56.102:2181(CONNECTED) 37] get /fq-name-to-uuid/network_ipam:default-domain:admin:ipam333
1d54fc41-8697-4747-ab1f-f85ad53ac59d
h)
Set data
* Set ID of IPAM "ipam333" in the "admin" project.
[zk: 192.168.56.102:2181(CONNECTED) 44] set /fq-name-to-uuid/network_ipam:default-domain:admin:ipam333 1d54fc41-8697-4747-ab1f-f85ad53ac599
How to Ubuntu Install SimpleScreenRecorder and Start Recording with Audio
1)
Install Simple Screen Recorder
http://www.maartenbaert.be/simplescreenrecorder/#download
#sudo add-apt-repository ppa:maarten-baert/simplescreenrecorder
#sudo apt-get update
#sudo apt-get install simplescreenrecorder
2)
Load module-loopback to record Audio
#pactl load-module module-loopback
3)
UnLoad module-loopback After Recording
#pactl unload-module module-loopback
4)
How to Start Recording
4a)
Minimize the simplescreenrecorder window
4b)
Press "Ctrl + r" to Start the Recording
Press "Ctrl + r" again to Pause the Recording
5)
How to Stop Recording and Save it.
5a)
Press "Ctrl + r" to Pause the Recording
5b)
Open simplescreenrecorder window and click on "Save recoding" button.
Install Simple Screen Recorder
http://www.maartenbaert.be/simplescreenrecorder/#download
#sudo add-apt-repository ppa:maarten-baert/simplescreenrecorder
#sudo apt-get update
#sudo apt-get install simplescreenrecorder
2)
Load module-loopback to record Audio
#pactl load-module module-loopback
3)
UnLoad module-loopback After Recording
#pactl unload-module module-loopback
4)
How to Start Recording
4a)
Minimize the simplescreenrecorder window
4b)
Press "Ctrl + r" to Start the Recording
Press "Ctrl + r" again to Pause the Recording
5)
How to Stop Recording and Save it.
5a)
Press "Ctrl + r" to Pause the Recording
5b)
Open simplescreenrecorder window and click on "Save recoding" button.
Thursday, March 5, 2015
Python How to find all submodules of a module
How to find all submodules of module kazoo
>>> import kazoo
>>> import pkgutil
>>>
>>>
>>>
>>> dir(kazoo)
['__builtins__', '__doc__', '__file__', '__name__', '__package__', '__path__']
>>>
>>>
>>>
>>>#List all submodules of module kazoo
>>> for x in pkgutil.iter_modules(kazoo.__path__):
... x
...
(, 'client', False)
(, 'exceptions', False)
(, 'handlers', True)
(, 'hosts', False)
(, 'interfaces', False)
(, 'loggingsupport', False)
(, 'protocol', True)
(, 'recipe', True)
(, 'retry', False)
(, 'security', False)
(, 'testing', True)
(, 'tests', True)
>>>
>>>
>>>
>>> kazoo.client
Traceback (most recent call last):
File "", line 1, in
AttributeError: 'module' object has no attribute 'client'
>>>
>>>
>>>
>>> import kazoo.client
>>> import kazoo.exceptions
>>> import kazoo.handlers
>>>
>>>
OR
>>>#List all submodules of module kazoo
>>> for x in pkgutil.walk_packages(kazoo.__path__):
... x
...
(, 'client', False)
(, 'exceptions', False)
(, 'handlers', True)
(, 'hosts', False)
(, 'interfaces', False)
(, 'loggingsupport', False)
(, 'protocol', True)
(, 'recipe', True)
(, 'retry', False)
(, 'security', False)
(, 'testing', True)
(, 'tests', True)
>>>
>>>
>>>
>>> import kazoo
>>> import pkgutil
>>>
>>>
>>>
>>> dir(kazoo)
['__builtins__', '__doc__', '__file__', '__name__', '__package__', '__path__']
>>>
>>>
>>>
>>>#List all submodules of module kazoo
>>> for x in pkgutil.iter_modules(kazoo.__path__):
... x
...
(
(
(
(
(
(
(
(
(
(
(
(
>>>
>>>
>>>
>>> kazoo.client
Traceback (most recent call last):
File "
AttributeError: 'module' object has no attribute 'client'
>>>
>>>
>>>
>>> import kazoo.client
>>> import kazoo.exceptions
>>> import kazoo.handlers
>>>
>>>
OR
>>>#List all submodules of module kazoo
>>> for x in pkgutil.walk_packages(kazoo.__path__):
... x
...
(
(
(
(
(
(
(
(
(
(
(
(
>>>
>>>
>>>
How to Install Python SimpleGUI SimpleGUICS2Pygame for your CodeSkulptor Programs
1)
Install
#pip install SimpleGUICS2Pygame
2)
#python
>>> import SimpleGUICS2Pygame.simpleguics2pygame as simplegui
>>>
>>> #Event handler
... def tick():
... print "tick!"
...
>>> #Register handler
... timer = simplegui.create_timer(1000,tick)
>>>
>>>
>>> #Start timer
... timer.start()
>>> tick!
tick!
tick!
tick!
tick!
tick!
Install
#pip install SimpleGUICS2Pygame
2)
#python
>>> import SimpleGUICS2Pygame.simpleguics2pygame as simplegui
>>>
>>> #Event handler
... def tick():
... print "tick!"
...
>>> #Register handler
... timer = simplegui.create_timer(1000,tick)
>>>
>>>
>>> #Start timer
... timer.start()
>>> tick!
tick!
tick!
tick!
tick!
tick!
How to install simplegui in Ubuntu Linux
1)
Install Tkinter
#sudo apt-get install python-tk
2)
Install simplegui
#pip install simplegui
OR
#easy_install simplegui
Install Tkinter
#sudo apt-get install python-tk
2)
Install simplegui
#pip install simplegui
OR
#easy_install simplegui