当前位置: 首页 > news >正文

python+docker实现分布式存储的demo

test.py代码
 

#test.py
from flask import Flask, request, jsonify
import requests
import sys
import threadingapp = Flask(__name__)# 存储数据
data_store = {}# 节点列表,通过环境变量传入
nodes = []
current_node = None@app.route('/set', methods=['POST'])
def set_value():key = request.json.get('key')value = request.json.get('value')data_store[key] = value# 同步到其他节点for node in nodes:if node != current_node:try:requests.post(f'http://{node}/sync', json={'key': key, 'value': value})except requests.exceptions.RequestException:pass  # 可以添加更好的错误处理return jsonify({'status': 'success'}), 200@app.route('/get', methods=['GET'])
def get_value():key = request.args.get('key')value = data_store.get(key, None)return jsonify({'value': value}), 200@app.route('/sync', methods=['POST'])
def sync():key = request.json.get('key')value = request.json.get('value')data_store[key] = valuereturn jsonify({'status': 'synced'}), 200@app.route('/nodes', methods=['GET'])
def get_nodes():return jsonify({'nodes': nodes}), 200def run_app(port):app.run(host='0.0.0.0', port=port)if __name__ == '__main__':# 从环境变量获取节点信息current_node = sys.argv[1]  # 例如:'node1:5000'nodes = sys.argv[2].split(',')  # 例如:'node1:5000,node2:5001,node3:5002'port = int(current_node.split(':')[1])run_app(port)

Dockerfile:

# Dockerfile
FROM python:3.9-slimWORKDIR /appCOPY test.py /app/test.py
COPY requirements.txt /app/requirements.txtRUN pip install --no-cache-dir -r requirements.txtEXPOSE 5000CMD ["python", "test.py"]

docker-compose.yml

version: '3'services:node1:build: .container_name: node1ports:- "5000:5000"environment:- NODE_NAME=node1command: ["python", "test.py", "node1:5000", "node1:5000,node2:5000,node3:5000"]networks:- dnetworknode2:build: .container_name: node2ports:- "5001:5000"environment:- NODE_NAME=node2command: ["python", "test.py", "node2:5000", "node1:5000,node2:5000,node3:5000"]networks:- dnetworknode3:build: .container_name: node3ports:- "5002:5000"environment:- NODE_NAME=node3command: ["python", "test.py", "node3:5000", "node1:5000,node2:5000,node3:5000"]networks:- dnetworknetworks:dnetwork:driver: bridge

requirements.txt

Flask
requests

上面的demo是用docker-compose启动三个容器(这三个容器的镜像都是由同一个Dockerfile实现的),然后实现的功能就是,比如我往容器一存东西,然后可以在容器2,容器3查看到

curl测试

curl -X POST -H "Content-Type: application/json" \-d '{"key": "foo", "value": "bar"}' \http://localhost:5000/setcurl http://localhost:5002/get?key=foo

然后我们以后还可以扩展,将docker-compose启动的镜像换为三个不同的镜像来完成你的项目需求(例如分布式机器学习,训练模型等等),整体的demo是搭起来了,后面你的具体需求就需要你自己修改实现了

  • docker-compose down:停止并移除当前运行的容器。
  • docker-compose build:重新构建 Docker 镜像,确保使用最新的配置。
  • docker-compose up -d:在后台启动更新后的容器。

相关文章:

python+docker实现分布式存储的demo

test.py代码 #test.py from flask import Flask, request, jsonify import requests import sys import threadingapp Flask(__name__)# 存储数据 data_store {}# 节点列表,通过环境变量传入 nodes [] current_node Noneapp.route(/set, methods[POST]) def …...

go-blueprint create exit status 1

1. 异常信息 2024/12/06 10:59:19 Could not initialize go.mod in new project exit status 1 2024/12/06 10:59:19 Problem creating files for project. exit status 1 Error: exit status 12. 排查思路 手动进行go mod init查看手动的报错解决报错 3. 解决问题 发现是GO11…...

如何更改Git用户名 - 本地与全局设置指南

在开发过程中,当使用Git作为版本控制系统时,可能会遇到需要更改用户名的情况,适时更新Git配置是保持项目管理效率的重要环节。更改Git用户名可以帮助确保您的提交反映了当前的用户身份,这对于项目的协作和历史记录跟踪至关重要。 …...

Node.js JWT认证教程

Node.js JWT认证教程 1. 项目介绍 JSON Web Token (JWT) 是一种安全的跨域身份验证解决方案,在现代Web应用中广泛使用。本教程将详细讲解如何在Node.js中实现JWT认证。 2. 项目准备 2.1 初始化项目 # 创建项目目录 mkdir nodejs-jwt-auth cd nodejs-jwt-auth# …...

【青牛科技】应用于音频信号处理系统的D258 是由两个独立的高增益运算放大器组成

概述: D258是由两个独立的高增益运算放大器组成。可以是单电源工作,也可以是双电源工作,电源的电流消耗与电源电压大小无关。应用范围包括变频放大器、DC增益部件和所有常规运算放大电路。 主要特点: ● 可单电源或双电源 工作 ● 在一个封…...

HTML Input 文件上传功能全解析:从基础到优化

🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…...

小程序 —— Day1

组件 — view和scroll-view view 类似于HTML中的div,是一个块级元素 案例:通过view组件实现页面的基础布局 scroll-view 可滚动的视图区域,用来实现滚动列表效果 案例:实现纵向滚动效果 scroll-x属性:允许横向滚动…...

4.5 TCP 报文段的首部格式

欢迎大家订阅【计算机网络】学习专栏,开启你的计算机网络学习之旅! 文章目录 前言1 TCP 报文段的基本结构2 固定部分2.1 源端口与目的端口2.2 序号2.3 确认号2.4 数据偏移2.5 保留字段2.6 控制位2.7 窗口2.8 检验和2.9 紧急指针 3 可变部分3.1 选项3.2 填…...

SQL 获取今天的当月开始结束范围:

使用 GETDATE() 结合 DATEADD() 和 DATEDIFF() 函数来获取当前月的开始和结束时间范围。以下是实现当前月时间范围查询的 SQL&#xff1a; FDATE > DATEADD(MONTH, DATEDIFF(MONTH, 0, GETDATE()), 0) FDATE < DATEADD(MONTH, DATEDIFF(MONTH, 0, GETDATE()) 1, 0) …...

Qt复习学习

https://www.bilibili.com/video/BV1Jp4y167R9/?spm_id_from333.999.0.0&vd_sourceb3723521e243814388688d813c9d475f https://subingwen.cn/qt/qt-primer/#1-4-Qt%E6%A1%88%E4%BE%8B https://subingwen.cn/qt/ https://download.qt.io/archive/qt/1.1Qt的特点 1.2QT中的…...

Leetcode经典题5--轮转数组

题目描述 给定一个整数数组 nums&#xff0c;将数组中的元素向右轮转 k 个位置&#xff0c;其中 k 是非负数。 输入输出示例 &#xff1a; 输入: nums [1,2,3,4,5,6,7], k 3 输出: [5,6,7,1,2,3,4] 解释: 向右轮转 1 步: [7,1,2,3,4,5,6] 向右轮转 2 步: [6,7,1,2,3,4,5] 向右…...

C++的一些经典算法

以下是C的一些经典算法&#xff1a; 一、排序算法 冒泡排序&#xff08;Bubble Sort&#xff09; 原理&#xff1a; 它重复地走访过要排序的数列&#xff0c;一次比较两个元素&#xff0c;如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换…...

Windows环境中Python脚本开机自启动及其监控自启动

1 开机自启动 Windows 10/Windows Server 201X具有一个名为“启动”的已知文件夹&#xff0c;系统每次启动开始自动运行应用程序、快捷方式和脚本时都会检查该文件夹&#xff0c;而无需额外配置。 要在Windows启动时运行脚本&#xff0c;先使用WindowsR快捷键打开“运行”对话…...

XML 语言随笔

XML的含义 XML&#xff08;eXtensible Markup Language&#xff0c;可扩展标记语言&#xff09;是一种用于存储和传输数据的标记语言。XML与HTML&#xff08;HyperText Markup Language&#xff0c;超文本标记语言&#xff09;类似&#xff0c;但XML的设计目的是描述数据&…...

E卷-分割数组的最大差值

分割数组的最大差值 问题描述 给定一个由若干整数组成的数组 n u m s nums nums,可以在数组内的任意位置进行分割,将该数组分割成两个非空子数组(即左数组和右数组)。分别对子数组求和得到两个值,然后计算这两个值的差值。请输出所有分割方案中,差值的最大值。 输入格…...

基于SpringBoot校园台球厅人员与设备管理系统设计与实现

1.1课题背景与意义 在Internet高速发展的今天&#xff0c;计算机的应用几乎完全覆盖我们生活的各个领域&#xff0c;互联网在经济&#xff0c;生活等方面有着举足轻重的地位&#xff0c;成为人们资源共享&#xff0c;信息快速传递的重要渠道。在中国&#xff0c;网上管理的兴起…...

异步FIFO的实现

异步FIFO是verilog中常见的设计&#xff0c;通常用于不同时钟域下的数据同步。 在实现 FIFO 时&#xff0c;无论是同步 FIFO 还是异步 FIFO &#xff0c;通常会通过双口 RAM &#xff08; Dual Port RAM &#xff09;并添加一些必要的逻辑来实现。双口 RAM的设计如下&#xff1…...

关于找工作的一些感悟

2024年找工作可以说难度十分艰巨&#xff0c;尤其是年底&#xff0c;除了外包公司还在不停的招聘以外&#xff0c;自研的公司基本很少在招聘了。今年有一个很大的感受就是投递了简历可能都没有几个人回复&#xff0c;即使有人回复百分之八十都是拒绝的&#xff0c;拒绝的理由一…...

docker 相关问题记录

docker mysql 一直重启解决办法&#xff08;断电或者重启&#xff09; 一直重启。。因为是内部开发&#xff0c;也没有备份最新的。所以不能删了重来。 方法&#xff1a; docker logs mysql5.7 看到错误跟innodb有关。 具体原因可以参考 http://acuilab.com/articles/2019/1…...

Devops 实践

Devops 实践 基本概念jenkins实践安装jenkins仓库环境准备代码环境准备第一次构建持续集成持续部署集成插件 优秀实践心得体会 参考 摘要&#xff1a;本文首先将介绍一些基本概念&#xff0c;包括Devops&#xff0c;CI/CD等&#xff0c;然后基于知名开源CI/CD工具jenkins进行实…...

基于Hive的淘宝用户购物行为数据分析及可视化

第1章 绪论1.1 课题背景互联网技术迅猛发展&#xff0c;电子商务平台聚集了庞大的用户数据&#xff0c;其中包含着大量的用户行为信息以及消费习惯。淘宝是中国最大的电子商务平台之一&#xff0c;其用户购物行为数据具有很高的研究价值。在大数据的背景下&#xff0c;怎样对数…...

c | 穿 |pld | 的 |女王 |2222

我通过百度网盘分享的文件&#xff1a;穿达的王2&#xff08;20... 链接&#xff1a;https://pan.baidu.com/s/1yiYXVmvY-KhDjwWzL2t81w?pwdj775 提取码&#xff1a;j775...

Android Recovery 模式工作原理与定制实战

Recovery 是 Android 的"救命系统",负责 OTA 升级、恢复出厂、用户数据加密管理。本文剖析 Recovery 的架构、启动流程、与主系统的通信机制,并演示如何修改并构建一个自定义 Recovery。一、Recovery 到底是什么? 很多人以为 Recovery 是 Android 系统的一个"模…...

基于Keel-Kit的GitOps自动化:轻量级镜像更新与部署实践

1. 项目概述&#xff1a;一个为现代应用交付而生的“舵手工具箱”如果你和我一样&#xff0c;长期在云原生和微服务架构的浪潮里扑腾&#xff0c;那你一定对“应用交付”这四个字背后的复杂性深有体会。从代码提交到最终服务上线&#xff0c;中间横亘着构建、打包、部署、配置、…...

企业内部分享Taotoken在代码审查与生成场景下的应用实践

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 企业内部分享Taotoken在代码审查与生成场景下的应用实践 在软件开发团队中&#xff0c;代码审查与代码生成是提升代码质量、保障项…...

Newhaven 5.0英寸TFT显示屏技术解析与应用指南

1. Newhaven 5.0英寸TFT显示屏核心特性解析 1.1 3M增强膜技术解析 这款5.0英寸TFT显示屏最显著的技术亮点在于采用了3M专利的增强膜技术。在实际应用中&#xff0c;我发现这种增强膜通过特殊的光学结构设计&#xff0c;能够有效提升背光利用率。具体来说&#xff0c;它采用了多…...

揭秘AMD处理器底层控制:Ryzen SDT调试工具从入门到精通

揭秘AMD处理器底层控制&#xff1a;Ryzen SDT调试工具从入门到精通 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https://g…...

注意力机制新思路:拆解CoordAttention,看它如何用两个1D全局池搞定“位置+通道”信息

注意力机制新思路&#xff1a;拆解CoordAttention&#xff0c;看它如何用两个1D全局池搞定“位置通道”信息 在计算机视觉领域&#xff0c;注意力机制已经成为提升模型性能的关键组件。传统的通道注意力机制&#xff08;如SE模块&#xff09;虽然能有效建模通道间关系&#xff…...

免费解锁B站大会员4K视频:Python下载器完整使用指南

免费解锁B站大会员4K视频&#xff1a;Python下载器完整使用指南 【免费下载链接】bilibili-downloader B站视频下载&#xff0c;支持下载大会员清晰度4K&#xff0c;持续更新中 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-downloader 还在为B站上的精彩视频…...

超级记忆与智能体框架:构建LLM长期记忆系统的开源实践

1. 项目概述与核心价值最近在折腾个人知识库和AI工具链的朋友&#xff0c;估计都绕不开一个核心痛点&#xff1a;如何让AI真正“理解”并记住我们给它的私有信息。无论是想打造一个能回答公司内部文档问题的智能助手&#xff0c;还是想构建一个能基于个人笔记进行深度对话的聊天…...