V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
longmeier90
V2EX  ›  Python

有用 Python +django 搞过微服务的吗?都需要了解哪些知识,有没有好的建议。

  •  
  •   longmeier90 · Apr 29, 2021 · 5751 views
    This topic created in 1827 days ago, the information mentioned may be changed or developed.

    最近公司想把一个大的项目,拆分出各个模块出来,自己现在的项目是用 django+mysql 开发的也了解点 docker 、rabbitmq 。对部署微服务整个架构还不是太了解,有没有搞过的大佬给指点指点。 假如按照目前我们的条件适合怎么弄,还需要了解哪些知识。

    18 replies    2021-05-08 09:08:40 +08:00
    xuanbg
        1
    xuanbg  
       Apr 29, 2021
    微服务最关键的组件只有三个:注册中心、配置中心和网关。所以,你只需要把这 3 个东西跑起来,然后你开发的服务能够注册到注册中心,能获取到配置就行了。别的譬如限流、降级、链路追逐什么的都不是必要的,可以有需要的时候再搞,甚至自己搞。
    jackzzh
        2
    jackzzh  
       Apr 29, 2021
    zhoudaiyu
        3
    zhoudaiyu  
    PRO
       Apr 29, 2021
    上 k8s,用 k8s 那套
    Seahurt
        4
    Seahurt  
       Apr 29, 2021   ❤️ 1
    我们公司之前也是 django 的项目想拆成微服务,但是发现拆成微服务后人手不够,就放弃了。django 单项目一两个人就搞定了,拆成微服务,每个服务都要有人去负责,一个人负责多个项目时你会发现,我本来可以 ORM 直接获取数据的,现在必须得搞个 API 才行,工作量翻了几倍
    freemoon
        5
    freemoon  
       Apr 29, 2021
    人手不够别折腾,项目不大别折腾,不懂微服务更别折腾。
    longmeier90
        6
    longmeier90  
    OP
       Apr 29, 2021
    @lasuar 我觉的不懂可以先学习学习,等了解透彻了就可以弄了呀。
    longmeier90
        7
    longmeier90  
    OP
       Apr 29, 2021
    @Seahurt 系统越单一项目管理越简单,越复杂越容易出问题,对于小团队确实越简单越好,但是我们也不能满足于此,而是要往长远考虑,可以先学习学习
    longmeier90
        8
    longmeier90  
    OP
       Apr 29, 2021
    @xuanbg 谢谢大佬
    xuanbg
        9
    xuanbg  
       Apr 29, 2021
    @longmeier90 你的理解是正确的,而且微服务本身不增加工作量,反而能有效降低工作量。但前提是得正确拆分服务,顺带着还要懂点运维知识。
    linvaux
        10
    linvaux  
       Apr 29, 2021
    微服务 == 招人
    LeeReamond
        11
    LeeReamond  
       Apr 30, 2021
    微服务和 django 放在一起是很奇怪的组合,django 定位自己是一套解决方案,而不是一个 http 框架,同样的微服务架构,使用 django 会消耗更多资源,获得更低性能,并浪费 django 的一些设计特性,为什么要这么做呢
    coderxy
        12
    coderxy  
       Apr 30, 2021
    微服务关键的几个名词 服务领域拆分,服务注册、发现、治理,微服务网关 再进一步就是熔断,限流,流量染色,分布式事务等等。
    chaleaoch
        13
    chaleaoch  
       May 4, 2021
    楼主咋样有进展吗?
    longmeier90
        14
    longmeier90  
    OP
       May 6, 2021
    @chaleaoch 没有了,先了解了解做微服务都需要什么技术储备。现在说的很多东西都还不懂,现阶段主要是了解和学习
    chaleaoch
        15
    chaleaoch  
       May 6, 2021
    @longmeier90 我俩技术栈差不多, 而且我也对微服务很有兴趣, 一起学习. 多交流.
    longmeier90
        16
    longmeier90  
    OP
       May 6, 2021
    @chaleaoch 可以,加我微信 longmeier99 以后方便交流
    chaleaoch
        17
    chaleaoch  
       May 7, 2021
    @xuanbg
    @coderxy
    大佬问一下 istio k8s 这些概念 和运维更紧密一些还是和开发更紧密一些,还是 都很紧密?

    我想自己搭一套架子 是不是必须得精通 k8s?
    xuanbg
        18
    xuanbg  
       May 8, 2021
    @chaleaoch 自己搭一套架子,不必精通 k8s 。基本的功能能够照着说明文档 /博客用起来就行了。至于 istio 什么的,和 spring cloud 的微服务组件也没啥本质上的区别,也就是相当于一个功能更强大的网关?反正微服务 3 个核心组件:注册中心、配置中心和网关,无论你用哪家的产品都没关系,搞起来就行了。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3460 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 787ms · UTC 04:23 · PVG 12:23 · LAX 21:23 · JFK 00:23
    ♥ Do have faith in what you're doing.