sbcli-dev 3.8.70__zip → 3.8.72__zip
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/PKG-INFO +1 -1
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/env_var +1 -1
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/sbcli_dev.egg-info/PKG-INFO +1 -1
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_cli/cli.py +8 -8
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/constants.py +1 -1
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/device_controller.py +21 -21
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/health_controller.py +2 -2
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/storage_node_monitor.py +8 -3
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/storage_node_ops.py +4 -4
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/README.md +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/pyproject.toml +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/sbcli_dev.egg-info/SOURCES.txt +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/sbcli_dev.egg-info/dependency_links.txt +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/sbcli_dev.egg-info/entry_points.txt +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/sbcli_dev.egg-info/requires.txt +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/sbcli_dev.egg-info/top_level.txt +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/setup.cfg +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/setup.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_cli/main.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/__init__.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/cluster_ops.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/cnode_client.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/compute_node_ops.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/__init__.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/caching_node_controller.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/cluster_events.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/device_events.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/events_controller.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/lvol_controller.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/lvol_events.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/mgmt_events.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/pool_controller.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/pool_events.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/snapshot_controller.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/snapshot_events.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/storage_events.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/tasks_controller.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/tasks_events.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/distr_controller.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/kv_store.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/mgmt_node_ops.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/__init__.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/base_model.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/caching_node.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/cluster.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/compute_node.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/deployer.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/events.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/global_settings.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/iface.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/job_schedule.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/lvol_model.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/mgmt_node.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/nvme_device.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/pool.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/port_stat.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/snapshot.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/stats.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/models/storage_node.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/pci_utils.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/rpc_client.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/__init__.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/alerting/alert_resources.yaml.j2 +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/alerting/alert_rules.yaml +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/clean_local_storage_deploy.sh +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/config_docker.sh +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/dashboard.yml +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/dashboards/cluster.json +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/dashboards/devices.json +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/dashboards/lvols.json +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/dashboards/node-exporter.json +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/dashboards/nodes.json +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/dashboards/pools.json +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/datasource.yml +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/db_config_double.sh +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/db_config_single.sh +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/deploy_stack.sh +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/docker-compose-swarm-monitoring.yml +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/docker-compose-swarm.yml +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/haproxy.cfg +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/install_deps.sh +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/objstore.yml +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/prometheus.yml +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/run_ssh.sh +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/set_db_config.sh +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/stack_deploy_wait.sh +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/__init__.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/cached_lvol_stat_collector.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/caching_node_monitor.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/cap_monitor.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/capacity_and_stats_collector.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/device_monitor.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/distr_event_collector.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/health_check_service.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/install_service.sh +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/log_agg_service.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/lvol_monitor.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/lvol_stat_collector.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/main_distr_event_collector.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/mgmt_node_monitor.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/new_device_discovery.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/port_stat_collector.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/remove_service.sh +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/service_template.service +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/spdk_http_proxy_server.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/tasks_runner_failed_migration.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/tasks_runner_migration.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/tasks_runner_new_dev_migration.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/tasks_runner_node_add.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/tasks_runner_restart.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/shell_utils.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/snode_client.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/utils.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/__init__.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/app.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/auth_middleware.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/__init__.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/caching_node_ops.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/caching_node_ops_k8s.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/node_api_basic.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/node_api_caching_docker.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/node_api_caching_ks.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/snode_ops.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/snode_ops_k8s.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/web_api_caching_node.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/web_api_cluster.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/web_api_deployer.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/web_api_device.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/web_api_lvol.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/web_api_mgmt_node.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/web_api_pool.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/web_api_snapshot.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/blueprints/web_api_storage_node.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/caching_node_app.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/caching_node_app_k8s.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/node_utils.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/node_webapp.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/snode_app.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/snode_app_k8s.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/static/delete.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/static/deploy.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/static/deploy_cnode.yaml +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/static/deploy_spdk.yaml +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/static/is_up.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/static/list_deps.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/static/rpac.yaml +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/static/tst.py +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/templates/caching_deploy_spdk.yaml.j2 +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/templates/storage_deploy_spdk.yaml.j2 +0 -0
- {sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_web/utils.py +0 -0
|
@@ -145,12 +145,12 @@ class CLIWrapper:
|
|
|
145
145
|
'io_error_on_unmap', 'io_error_on_all', 'discard_io_all',
|
|
146
146
|
'hotplug_removal'], default='full_pass_through')
|
|
147
147
|
|
|
148
|
-
sub_command = self.add_sub_command(subparser, "jm-device-testing-mode", 'Set device testing mode')
|
|
149
|
-
sub_command.add_argument("device_id", help='Device UUID')
|
|
150
|
-
sub_command.add_argument("mode", help='Testing mode', choices=[
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
148
|
+
# sub_command = self.add_sub_command(subparser, "jm-device-testing-mode", 'Set device testing mode')
|
|
149
|
+
# sub_command.add_argument("device_id", help='Device UUID')
|
|
150
|
+
# sub_command.add_argument("mode", help='Testing mode', choices=[
|
|
151
|
+
# 'full_pass_through', 'io_error_on_read', 'io_error_on_write',
|
|
152
|
+
# 'io_error_on_unmap', 'io_error_on_all', 'discard_io_all',
|
|
153
|
+
# 'hotplug_removal'], default='full_pass_through')
|
|
154
154
|
|
|
155
155
|
sub_command = self.add_sub_command(subparser, "get-device", 'Get storage device by id')
|
|
156
156
|
sub_command.add_argument("device_id", help='the devices\'s UUID')
|
|
@@ -791,8 +791,8 @@ class CLIWrapper:
|
|
|
791
791
|
|
|
792
792
|
elif sub_command == "device-testing-mode":
|
|
793
793
|
ret = device_controller.set_device_testing_mode(args.device_id, args.mode)
|
|
794
|
-
elif sub_command == "jm-device-testing-mode":
|
|
795
|
-
|
|
794
|
+
# elif sub_command == "jm-device-testing-mode":
|
|
795
|
+
# ret = device_controller.set_jm_device_testing_mode(args.device_id, args.mode)
|
|
796
796
|
|
|
797
797
|
elif sub_command == "remove-device":
|
|
798
798
|
ret = device_controller.device_remove(args.device_id, args.force)
|
|
@@ -11,7 +11,7 @@ LOG_WEB_DEBUG = True
|
|
|
11
11
|
|
|
12
12
|
INSTALL_DIR = os.path.dirname(os.path.realpath(__file__))
|
|
13
13
|
|
|
14
|
-
NODE_MONITOR_INTERVAL_SEC =
|
|
14
|
+
NODE_MONITOR_INTERVAL_SEC = 5
|
|
15
15
|
DEVICE_MONITOR_INTERVAL_SEC = 5
|
|
16
16
|
STAT_COLLECTOR_INTERVAL_SEC = 60*5 # 5 minutes
|
|
17
17
|
LVOL_STAT_COLLECTOR_INTERVAL_SEC = 5
|
|
@@ -37,8 +37,8 @@ def device_set_state(device_id, state):
|
|
|
37
37
|
|
|
38
38
|
old_status = dev.status
|
|
39
39
|
device.status = state
|
|
40
|
-
distr_controller.send_dev_status_event(device, device.status)
|
|
41
40
|
snode.write_to_db(db_controller.kv_store)
|
|
41
|
+
distr_controller.send_dev_status_event(device, device.status)
|
|
42
42
|
device_events.device_status_change(device, device.status, old_status)
|
|
43
43
|
return True
|
|
44
44
|
|
|
@@ -295,26 +295,26 @@ def set_device_testing_mode(device_id, mode):
|
|
|
295
295
|
return ret
|
|
296
296
|
|
|
297
297
|
|
|
298
|
-
def set_jm_device_testing_mode(device_id, mode):
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
298
|
+
# def set_jm_device_testing_mode(device_id, mode):
|
|
299
|
+
# db_controller = DBController()
|
|
300
|
+
# snode = db_controller.get_storage_by_jm_id(device_id)
|
|
301
|
+
# if not snode:
|
|
302
|
+
# logger.error("node not found")
|
|
303
|
+
# return False
|
|
304
|
+
# jm_device = snode.jm_device
|
|
305
|
+
#
|
|
306
|
+
# if not snode.enable_test_device:
|
|
307
|
+
# logger.error("Test device is disabled on this storage node")
|
|
308
|
+
# return False
|
|
309
|
+
#
|
|
310
|
+
# logger.info(f"Set device:{device_id} Test mode:{mode}")
|
|
311
|
+
# # creating RPCClient instance
|
|
312
|
+
# rpc_client = RPCClient(
|
|
313
|
+
# snode.mgmt_ip, snode.rpc_port,
|
|
314
|
+
# snode.rpc_username, snode.rpc_password)
|
|
315
|
+
#
|
|
316
|
+
# ret = rpc_client.bdev_passtest_mode(jm_device.testing_bdev, mode)
|
|
317
|
+
# return ret
|
|
318
318
|
|
|
319
319
|
|
|
320
320
|
def device_remove(device_id, force=True):
|
|
@@ -82,7 +82,7 @@ def _check_node_rpc(rpc_ip, rpc_port, rpc_username, rpc_password, timeout=5, ret
|
|
|
82
82
|
|
|
83
83
|
def _check_node_api(ip):
|
|
84
84
|
try:
|
|
85
|
-
snode_api = SNodeClient(f"{ip}:5000", timeout=
|
|
85
|
+
snode_api = SNodeClient(f"{ip}:5000", timeout=5, retry=2)
|
|
86
86
|
logger.debug(f"Node API={ip}:5000")
|
|
87
87
|
info, _ = snode_api.info()
|
|
88
88
|
if info:
|
|
@@ -95,7 +95,7 @@ def _check_node_api(ip):
|
|
|
95
95
|
|
|
96
96
|
def _check_spdk_process_up(ip):
|
|
97
97
|
try:
|
|
98
|
-
snode_api = SNodeClient(f"{ip}:5000", timeout=
|
|
98
|
+
snode_api = SNodeClient(f"{ip}:5000", timeout=5, retry=2)
|
|
99
99
|
logger.debug(f"Node API={ip}:5000")
|
|
100
100
|
is_up, _ = snode_api.spdk_process_is_up()
|
|
101
101
|
logger.debug(f"SPDK is {is_up}")
|
|
@@ -105,9 +105,16 @@ def set_node_online(node):
|
|
|
105
105
|
|
|
106
106
|
def set_node_offline(node):
|
|
107
107
|
if node.status != StorageNode.STATUS_UNREACHABLE:
|
|
108
|
+
# set node unavailable
|
|
109
|
+
storage_node_ops.set_node_status(snode.get_id(), StorageNode.STATUS_UNREACHABLE)
|
|
110
|
+
|
|
111
|
+
# set devices unavailable
|
|
108
112
|
for dev in node.nvme_devices:
|
|
109
113
|
device_controller.device_set_unavailable(dev.get_id())
|
|
110
|
-
|
|
114
|
+
|
|
115
|
+
# set jm dev offline
|
|
116
|
+
if snode.jm_device.status != JMDevice.STATUS_UNAVAILABLE:
|
|
117
|
+
device_controller.set_jm_device_state(snode.jm_device.get_id(), JMDevice.STATUS_UNAVAILABLE)
|
|
111
118
|
|
|
112
119
|
|
|
113
120
|
logger.info("Starting node monitor")
|
|
@@ -164,8 +171,6 @@ while True:
|
|
|
164
171
|
|
|
165
172
|
else:
|
|
166
173
|
set_node_offline(snode)
|
|
167
|
-
if snode.jm_device.status != JMDevice.STATUS_UNAVAILABLE:
|
|
168
|
-
device_controller.set_jm_device_state(snode.jm_device.get_id(), JMDevice.STATUS_UNAVAILABLE)
|
|
169
174
|
|
|
170
175
|
if not ping_check and not node_api_check and not spdk_process:
|
|
171
176
|
# restart on new node
|
|
@@ -256,7 +256,7 @@ def _create_jm_stack_on_raid(rpc_client, jm_nvme_bdevs, snode, after_restart):
|
|
|
256
256
|
alceml_name = f"alceml_jm_{snode.get_id()}"
|
|
257
257
|
|
|
258
258
|
nvme_bdev = raid_bdev
|
|
259
|
-
|
|
259
|
+
test_name = ""
|
|
260
260
|
# if snode.enable_test_device:
|
|
261
261
|
# test_name = f"{raid_bdev}_test"
|
|
262
262
|
# ret = rpc_client.bdev_passtest_create(test_name, raid_bdev)
|
|
@@ -325,7 +325,7 @@ def _create_jm_stack_on_raid(rpc_client, jm_nvme_bdevs, snode, after_restart):
|
|
|
325
325
|
logger.error(f"Failed to add: {pt_name} to the subsystem: {subsystem_nqn}")
|
|
326
326
|
return False
|
|
327
327
|
|
|
328
|
-
ret = rpc_client.get_bdevs(
|
|
328
|
+
ret = rpc_client.get_bdevs(raid_bdev)
|
|
329
329
|
|
|
330
330
|
return JMDevice({
|
|
331
331
|
'uuid': alceml_id,
|
|
@@ -749,7 +749,7 @@ def _connect_to_remote_devs(this_node):
|
|
|
749
749
|
|
|
750
750
|
rpc_client = RPCClient(
|
|
751
751
|
this_node.mgmt_ip, this_node.rpc_port,
|
|
752
|
-
this_node.rpc_username, this_node.rpc_password)
|
|
752
|
+
this_node.rpc_username, this_node.rpc_password, timeout=5, retry=2)
|
|
753
753
|
|
|
754
754
|
remote_devices = []
|
|
755
755
|
# connect to remote devs
|
|
@@ -783,7 +783,7 @@ def _connect_to_remote_jm_devs(this_node):
|
|
|
783
783
|
|
|
784
784
|
rpc_client = RPCClient(
|
|
785
785
|
this_node.mgmt_ip, this_node.rpc_port,
|
|
786
|
-
this_node.rpc_username, this_node.rpc_password)
|
|
786
|
+
this_node.rpc_username, this_node.rpc_password, timeout=5, retry=2)
|
|
787
787
|
|
|
788
788
|
remote_devices = []
|
|
789
789
|
# connect to remote devs
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/controllers/caching_node_controller.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/alerting/alert_resources.yaml.j2
RENAMED
|
File without changes
|
|
File without changes
|
{sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/clean_local_storage_deploy.sh
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/dashboards/node-exporter.json
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/scripts/docker-compose-swarm-monitoring.yml
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/cached_lvol_stat_collector.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/capacity_and_stats_collector.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/main_distr_event_collector.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/tasks_runner_failed_migration.py
RENAMED
|
File without changes
|
|
File without changes
|
{sbcli_dev-3.8.70 → sbcli_dev-3.8.72}/simplyblock_core/services/tasks_runner_new_dev_migration.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|