ืื™ืš ืœืฉืจื•ื“ ืžืกื“ ื ืชื•ื ื™ื SQL ื‘ืžืื” ื”-21: ืขื ื ื™ื, Kubernetes ื•-PostgreSQL multimaster

ืฉืœื•ื ืชื•ืฉื‘ื™ ื—ื‘ืจื•ื‘ืกืง. ื”ืœื™ืžื•ื“ื™ื ื‘ืงื‘ื•ืฆื” ื”ืจืืฉื•ื ื” ืฉืœ ื”ืงื•ืจืก ืžืชื—ื™ืœื™ื ื”ื™ื•ื "PostgreSQL". ื‘ื”ืงืฉืจ ื–ื”, ื‘ืจืฆื•ื ื ื• ืœืกืคืจ ืœื›ื ื›ื™ืฆื“ ื”ืชืงื™ื™ื ื”ืกืžื™ื ืจ ื”ืžืงื•ื•ืŸ ื”ืคืชื•ื— ื‘ืงื•ืจืก ื–ื”.

ืื™ืš ืœืฉืจื•ื“ ืžืกื“ ื ืชื•ื ื™ื SQL ื‘ืžืื” ื”-21: ืขื ื ื™ื, Kubernetes ื•-PostgreSQL multimaster

ะ’ ื”ืฉื™ืขื•ืจ ื”ืคืชื•ื— ื”ื‘ื ื“ื™ื‘ืจื ื• ืขืœ ื”ืืชื’ืจื™ื ืฉืขื•ืžื“ื™ื ื‘ืคื ื™ ืžืกื“ื™ ื ืชื•ื ื™ื ืฉืœ SQL ื‘ืขื™ื“ืŸ ื”ืขื ื ื™ื ื•ื”-Kubernetes. ื‘ืžืงื‘ื™ืœ, ื‘ื“ืงื ื• ื›ื™ืฆื“ ืžืกื“ื™ ื ืชื•ื ื™ื ืฉืœ SQL ืžืกืชื’ืœื™ื ื•ืžืฉืชื ื™ื ื‘ื”ืฉืคืขืช ื”ืืชื’ืจื™ื ื”ืœืœื•.

ื”ื•ื•ื‘ื™ื ืจ ื ืขืจืš ื•ืœืจื™ ื‘ื–ืจื•ืงื•ื‘, Google Cloud Practice Delivery Manager ื‘-EPAM Systems.

ื›ืฉื”ืขืฆื™ื ื”ื™ื• ืงื˜ื ื™ื...

ืจืืฉื™ืช, ื‘ื•ืื• ื ื–ื›ื•ืจ ื›ื™ืฆื“ ื”ื—ืœื” ื”ื‘ื—ื™ืจื” ื‘-DBMS ื‘ืกื•ืฃ ื”ืžืื” ื”ืงื•ื“ืžืช. ืขื ื–ืืช, ื–ื” ืœื ื™ื”ื™ื” ืงืฉื”, ื›ื™ ื”ื‘ื—ื™ืจื” ืฉืœ DBMS ื‘ืื•ืชื ื™ืžื™ื ื”ืชื—ื™ืœื” ื•ื”ืกืชื™ื™ืžื” ืื•ืจืงืœ.

ืื™ืš ืœืฉืจื•ื“ ืžืกื“ ื ืชื•ื ื™ื SQL ื‘ืžืื” ื”-21: ืขื ื ื™ื, Kubernetes ื•-PostgreSQL multimaster

ื‘ืกื•ืฃ ืฉื ื•ืช ื”-90 ื•ืชื—ื™ืœืช ืฉื ื•ืช ื”-2, ื‘ืขืฆื ืœื ื”ื™ื™ืชื” ื‘ืจื™ืจื” ื‘ื›ืœ ื”ื ื•ื’ืข ืœื‘ืกื™ืกื™ ื ืชื•ื ื™ื ืชืขืฉื™ื™ืชื™ื™ื ื”ื ื™ืชื ื™ื ืœื”ืจื—ื‘ื”. ื›ืŸ, ื”ื™ื• IBM DBXNUMX, Sybase ื•ืขื•ื“ ื›ืžื” ืžืกื“ื™ ื ืชื•ื ื™ื ืฉื”ื’ื™ืขื• ื•ื”ืœื›ื•, ืื‘ืœ ื‘ืื•ืคืŸ ื›ืœืœื™ ื”ื ืœื ื”ื™ื• ื›ืœ ื›ืš ืžื•ืจื’ืฉื™ื ืขืœ ืจืงืข ืื•ืจืงืœ. ื‘ื”ืชืื ืœื›ืš, ื”ื›ื™ืฉื•ืจื™ื ืฉืœ ื”ืžื”ื ื“ืกื™ื ืฉืœ ืื•ืชื ื–ืžื ื™ื ื”ื™ื• ืงืฉื•ืจื™ื ืื™ื›ืฉื”ื• ืœื‘ื—ื™ืจื” ื”ื™ื—ื™ื“ื” ืฉืงื™ื™ืžืช.

Oracle DBA ื”ื™ื” ืฆืจื™ืš ืœื”ื™ื•ืช ืžืกื•ื’ืœ:

  • ื”ืชืงืŸ ืืช Oracle Server ืžืขืจืš ื”ื”ืคืฆื”;
  • ืœื”ื’ื“ื™ืจ ืืช Oracle Server:

  • init.ora;
  • listener.ora;

- ืœื™ืฆื•ืจ:

  • ืžืจื—ื‘ื™ ืฉื•ืœื—ืŸ;
  • ืชึธื›ึฐื ึดื™ืช;
  • ืžืฉืชืžืฉื™ื;

- ืœื‘ืฆืข ื’ื™ื‘ื•ื™ ื•ืฉื—ื–ื•ืจ;
- ืœื‘ืฆืข ื ื™ื˜ื•ืจ;
- ืœื”ืชืžื•ื“ื“ ืขื ื‘ืงืฉื•ืช ืœื ืื•ืคื˜ื™ืžืœื™ื•ืช.

ื™ื—ื“ ืขื ื–ืืช, ืœื ื”ื™ื™ืชื” ื“ืจื™ืฉื” ืžื™ื•ื—ื“ืช ืž-Oracle DBA:

  • ืœื”ื™ื•ืช ืžืกื•ื’ืœ ืœื‘ื—ื•ืจ ืืช ื”-DBMS ื”ืื•ืคื˜ื™ืžืœื™ ืื• ื˜ื›ื ื•ืœื•ื’ื™ื” ืื—ืจืช ืœืื—ืกื•ืŸ ื•ืขื™ื‘ื•ื“ ื ืชื•ื ื™ื;
  • ืœืกืคืง ื–ืžื™ื ื•ืช ื’ื‘ื•ื”ื” ื•ืžื“ืจื’ื™ื•ืช ืื•ืคืงื™ืช (ื–ื• ืœื ืชืžื™ื“ ื”ื™ื™ืชื” ื‘ืขื™ื” ืฉืœ DBA);
  • ื™ื“ืข ื˜ื•ื‘ ื‘ืชื—ื•ื ื”ื ื•ืฉื, ืชืฉืชื™ืช, ืืจื›ื™ื˜ืงื˜ื•ืจืช ื™ื™ืฉื•ืžื™ื, ืžืขืจื›ืช ื”ืคืขืœื”;
  • ืœื˜ืขื•ืŸ ื•ืœืคืจื•ืง ื ืชื•ื ื™ื, ืœื”ืขื‘ื™ืจ ื ืชื•ื ื™ื ื‘ื™ืŸ DBMSs ืฉื•ื ื™ื.

ื‘ืื•ืคืŸ ื›ืœืœื™, ืื ืื ื—ื ื• ืžื“ื‘ืจื™ื ืขืœ ื”ื‘ื—ื™ืจื” ื‘ืื•ืชื ื™ืžื™ื, ื–ื” ื“ื•ืžื” ืœื‘ื—ื™ืจื” ื‘ื—ื ื•ืช ืกื•ื‘ื™ื™ื˜ื™ืช ื‘ืกื•ืฃ ืฉื ื•ืช ื”-80:

ืื™ืš ืœืฉืจื•ื“ ืžืกื“ ื ืชื•ื ื™ื SQL ื‘ืžืื” ื”-21: ืขื ื ื™ื, Kubernetes ื•-PostgreSQL multimaster

ื”ื–ืžืŸ ืฉืœื ื•

ืžืื–, ื›ืžื•ื‘ืŸ, ื”ืขืฆื™ื ื’ื“ืœื•, ื”ืขื•ืœื ื”ืฉืชื ื”, ื•ื–ื” ื”ืคืš ืœืžืฉื”ื• ื›ื–ื”:

ืื™ืš ืœืฉืจื•ื“ ืžืกื“ ื ืชื•ื ื™ื SQL ื‘ืžืื” ื”-21: ืขื ื ื™ื, Kubernetes ื•-PostgreSQL multimaster

ื’ื ืฉื•ืง ื”-DBMS ื”ืฉืชื ื”, ื›ืคื™ ืฉื ื™ืชืŸ ืœืจืื•ืช ื‘ื‘ื™ืจื•ืจ ืžื”ื“ื•ื— ื”ืื—ืจื•ืŸ ืฉืœ ื’ืจื˜ื ืจ:

ืื™ืš ืœืฉืจื•ื“ ืžืกื“ ื ืชื•ื ื™ื SQL ื‘ืžืื” ื”-21: ืขื ื ื™ื, Kubernetes ื•-PostgreSQL multimaster

ื•ื›ืืŸ ื™ืฉ ืœืฆื™ื™ืŸ ื›ื™ ืขื ื ื™ื, ืฉื”ืคื•ืคื•ืœืจื™ื•ืช ืฉืœื”ื ื”ื•ืœื›ืช ื•ื’ื•ื‘ืจืช, ื›ื‘ืฉื• ืืช ื”ื ื™ืฉื” ืฉืœื”ื. ืื ื ืงืจื ืืช ืื•ืชื• ื“ื•"ื— ืฉืœ ื’ืจื˜ื ืจ, ื ืจืื” ืืช ื”ืžืกืงื ื•ืช ื”ื‘ืื•ืช:

  1. ืœืงื•ื—ื•ืช ืจื‘ื™ื ื ืžืฆืื™ื ื‘ื“ืจืš ืœื”ืขื‘ืจืช ืืคืœื™ืงืฆื™ื•ืช ืœืขื ืŸ.
  2. ื˜ื›ื ื•ืœื•ื’ื™ื•ืช ื—ื“ืฉื•ืช ืžื•ืคื™ืขื•ืช ืœืจืืฉื•ื ื” ื‘ืขื ืŸ ื•ื–ื• ืœื ืขื•ื‘ื“ื” ืฉื”ืŸ ื™ืขื‘ืจื• ืื™ ืคืขื ืœืชืฉืชื™ืช ืฉืื™ื ื” ืขื ืŸ.
  3. ืžื•ื“ืœ ื”ืชืžื—ื•ืจ ืฉืœ ืชืฉืœื•ื ืœืคื™ ื“ืจื›ื• ื”ืคืš ืœื ืคื•ืฅ. ื›ืœ ืื—ื“ ืจื•ืฆื” ืœืฉืœื ืจืง ืขืœ ืžื” ืฉื”ื•ื ืžืฉืชืžืฉ, ื•ื–ื• ืืคื™ืœื• ืœื ื˜ืจื ื“, ืืœื ืคืฉื•ื˜ ื”ืฆื”ืจื” ืฉืœ ืขื•ื‘ื“ื”.

ืžื” ืขื›ืฉื™ื•?

ื”ื™ื•ื ื›ื•ืœื ื• ื‘ืขื ืŸ. ื•ื”ืฉืืœื•ืช ืฉืขื•ืœื•ืช ืขื‘ื•ืจื ื• ื”ืŸ ืฉืืœื•ืช ืฉืœ ื‘ื—ื™ืจื”. ื•ื–ื” ืขื ืง, ื’ื ืื ื ื“ื‘ืจ ืจืง ืขืœ ื”ื‘ื—ื™ืจื” ื‘ื˜ื›ื ื•ืœื•ื’ื™ื•ืช DBMS ื‘ืคื•ืจืžื˜ On-premises. ื™ืฉ ืœื ื• ื’ื ืฉื™ืจื•ืชื™ื ืžื ื•ื”ืœื™ื ื•-SaaS. ื›ืš, ื”ื‘ื—ื™ืจื” ืจืง ื”ื•ืคื›ืช ืงืฉื” ื™ื•ืชืจ ืžื“ื™ ืฉื ื”.

ื™ื—ื“ ืขื ืฉืืœื•ืช ืฉืœ ื‘ื—ื™ืจื”, ื™ืฉ ื’ื ื’ื•ืจืžื™ื ืžื’ื‘ื™ืœื™ื:

  • ืžื—ื™ืจ. ื˜ื›ื ื•ืœื•ื’ื™ื•ืช ืจื‘ื•ืช ืขื“ื™ื™ืŸ ืขื•ืœื•ืช ื›ืกืฃ;
  • ื›ื™ืฉื•ืจื™ื. ืื ืื ื—ื ื• ืžื“ื‘ืจื™ื ืขืœ ืชื•ื›ื ื” ื—ื•ืคืฉื™ืช, ืื– ืขื•ืœื” ืฉืืœืช ื”ื›ื™ืฉื•ืจื™ื, ืฉื›ืŸ ืชื•ื›ื ื” ื—ื•ืคืฉื™ืช ื“ื•ืจืฉืช ื™ื›ื•ืœืช ืžืกืคืงืช ืžื”ืื ืฉื™ื ืฉืคื•ืจืกื™ื ื•ืžืชืคืขืœื™ื ืื•ืชื”;
  • ืคื•ึผื ืงืฆึดื™ื•ึนื ึธืœึดื™. ืœื ืœื›ืœ ื”ืฉื™ืจื•ืชื™ื ื”ื–ืžื™ื ื™ื ื‘ืขื ืŸ ื•ื‘ื ื•ื™ื™ื, ืœืžืฉืœ, ืืคื™ืœื• ืขืœ ืื•ืชื• Postgres, ื™ืฉ ืืช ืื•ืชืŸ ืชื›ื•ื ื•ืช ื›ืžื• Postgres On-premises. ื–ื”ื• ื’ื•ืจื ื—ื™ื•ื ื™ ืฉืฆืจื™ืš ืœื“ืขืช ื•ืœื”ื‘ื™ืŸ. ื™ืชืจ ืขืœ ื›ืŸ, ื’ื•ืจื ื–ื” ื”ื•ืคืš ื—ืฉื•ื‘ ื™ื•ืชืจ ืžื”ื™ื“ืข ืขืœ ื›ืžื” ื™ื›ื•ืœื•ืช ื ืกืชืจื•ืช ืฉืœ DBMS ื™ื—ื™ื“.

ืžื” ืฆืคื•ื™ ืž-DA/DE ื›ืขืช:

  • ื”ื‘ื ื” ื˜ื•ื‘ื” ืฉืœ ืชื—ื•ื ื”ื ื•ืฉื ื•ืืจื›ื™ื˜ืงื˜ื•ืจืช ื”ืืคืœื™ืงืฆื™ื•ืช;
  • ื”ื™ื›ื•ืœืช ืœื‘ื—ื•ืจ ื ื›ื•ืŸ ืืช ื˜ื›ื ื•ืœื•ื’ื™ื™ืช DBMS ื”ืžืชืื™ืžื” ืชื•ืš ื”ืชื—ืฉื‘ื•ืช ื‘ืžืฉื™ืžื” ื”ืขื•ืžื“ืช ืขืœ ื”ืคืจืง;
  • ื”ื™ื›ื•ืœืช ืœื‘ื—ื•ืจ ืืช ื”ืฉื™ื˜ื” ื”ืื•ืคื˜ื™ืžืœื™ืช ืœื™ื™ืฉื•ื ื”ื˜ื›ื ื•ืœื•ื’ื™ื” ืฉื ื‘ื—ืจื” ื‘ื”ืงืฉืจ ืฉืœ ืžื’ื‘ืœื•ืช ืงื™ื™ืžื•ืช;
  • ื™ื›ื•ืœืช ืœื‘ืฆืข ื”ืขื‘ืจืช ื ืชื•ื ื™ื ื•ื”ื’ื™ืจื”;
  • ื™ื›ื•ืœืช ืœื™ื™ืฉื ื•ืœื”ืคืขื™ืœ ืคืชืจื•ื ื•ืช ื ื‘ื—ืจื™ื.

ื“ื•ื’ืžื” ืœืžื˜ื” ืžื‘ื•ืกืก ืขืœ GCP ืžื“ื’ื™ื ื›ื™ืฆื“ ื”ื‘ื—ื™ืจื” ื‘ื˜ื›ื ื•ืœื•ื’ื™ื” ื›ื–ื• ืื• ืื—ืจืช ืœืขื‘ื•ื“ื” ืขื ื ืชื•ื ื™ื ืคื•ืขืœืช ื‘ื”ืชืื ืœืžื‘ื ื” ืฉืœื”:

ืื™ืš ืœืฉืจื•ื“ ืžืกื“ ื ืชื•ื ื™ื SQL ื‘ืžืื” ื”-21: ืขื ื ื™ื, Kubernetes ื•-PostgreSQL multimaster

ืฉื™ืžื• ืœื‘ ืฉ-PostgreSQL ืื™ื ื• ื›ืœื•ืœ ื‘ืกื›ื™ืžื”, ื•ื–ืืช ืžืฉื•ื ืฉื”ื•ื ืžื•ืกืชืจ ืชื—ืช ื”ืžื™ื ื•ื— ืขื ืŸ SQL. ื•ื›ืฉื ื’ื™ืข ืœ-Cloud SQL, ืื ื—ื ื• ืฆืจื™ื›ื™ื ืœืขืฉื•ืช ื‘ื—ื™ืจื” ืฉื•ื‘:

ืื™ืš ืœืฉืจื•ื“ ืžืกื“ ื ืชื•ื ื™ื SQL ื‘ืžืื” ื”-21: ืขื ื ื™ื, Kubernetes ื•-PostgreSQL multimaster

ื™ืฉ ืœืฆื™ื™ืŸ ืฉื‘ื—ื™ืจื” ื–ื• ืœื ืชืžื™ื“ ื‘ืจื•ืจื”, ื•ืœื›ืŸ ืžืคืชื—ื™ ืืคืœื™ืงืฆื™ื•ืช ืžื•ื ื—ื™ื ืœืจื•ื‘ ืขืœ ื™ื“ื™ ืื™ื ื˜ื•ืื™ืฆื™ื”.

ืกืš ื”ื›ืœ:

  1. ื›ื›ืœ ืฉืžืชืงื“ืžื™ื ื™ื•ืชืจ, ื›ืš ืฉืืœืช ื”ื‘ื—ื™ืจื” ื”ื•ืคื›ืช ื“ื—ื•ืคื” ื™ื•ืชืจ. ื•ื’ื ืื ืžืกืชื›ืœื™ื ืจืง ืขืœ GCP, ืฉื™ืจื•ืชื™ื ืžื ื•ื”ืœื™ื ื•-SaaS, ืื– ืื™ื–ืฉื”ื• ืื–ื›ื•ืจ ืฉืœ RDBMS ืžื•ืคื™ืข ืจืง ื‘ืฉืœื‘ ื”ืจื‘ื™ืขื™ (ื•ืฉื Spanner ื ืžืฆื ื‘ืงืจื‘ืช ืžืงื•ื). ื‘ื ื•ืกืฃ, ื”ื‘ื—ื™ืจื” ื‘-PostgreSQL ืžื•ืคื™ืขื” ื‘ืฉืœื‘ ื”-4, ื•ืœืฆื™ื“ื” ื™ืฉ โ€‹โ€‹ื’ื MySQL ื•-SQL Server, ื›ืœื•ืžืจ ื™ืฉ ื”ืจื‘ื” ืžื”ื›ืœ, ืื‘ืœ ืฆืจื™ืš ืœื‘ื—ื•ืจ.
  2. ืืกื•ืจ ืœืฉื›ื•ื— ืžื’ื‘ืœื•ืช ืขืœ ืจืงืข ืคื™ืชื•ื™ื™ื. ื‘ืขืฆื ื›ื•ืœื ืจื•ืฆื™ื Spanner, ืื‘ืœ ื–ื” ื™ืงืจ. ื›ืชื•ืฆืื” ืžื›ืš, ื‘ืงืฉื” ื˜ื™ืคื•ืกื™ืช ื ืจืื™ืช ื‘ืขืจืš ื›ืš: "ื‘ื‘ืงืฉื” ืชืขืฉื” ืœื ื• Spanner ืื‘ืœ ื‘ืžื—ื™ืจ ืฉืœ Cloud SQL, ืืชื ืžืงืฆื•ืขื ื™ื!"

ืื™ืš ืœืฉืจื•ื“ ืžืกื“ ื ืชื•ื ื™ื SQL ื‘ืžืื” ื”-21: ืขื ื ื™ื, Kubernetes ื•-PostgreSQL multimaster

ืื‘ืœ ืžื” ืœืขืฉื•ืช?

ื‘ืœื™ ืœื˜ืขื•ืŸ ืฉื”ื ื”ืืžืช ื”ืื•ืœื˜ื™ืžื˜ื™ื‘ื™ืช, ื‘ื•ืื• ื ื’ื™ื“ ืืช ื”ื“ื‘ืจื™ื ื”ื‘ืื™ื:

ืขืœื™ื ื• ืœืฉื ื•ืช ืืช ื”ื’ื™ืฉื” ืฉืœื ื• ืœืœืžื™ื“ื”:

  • ืื™ืŸ ื˜ืขื ืœืœืžื“ ืืช ื”ืื•ืคืŸ ืฉื‘ื• ืœื™ืžื“ื• ืืช ื”-DBAs ื‘ืขื‘ืจ;
  • ื™ื“ืข ืขืœ ืžื•ืฆืจ ืื—ื“ ื›ื‘ืจ ืื™ื ื• ืžืกืคื™ืง;
  • ืื‘ืœ ืœื“ืขืช ืขืฉืจื•ืช ื‘ืจืžื” ืฉืœ ืื—ื“ ื–ื” ื‘ืœืชื™ ืืคืฉืจื™.

ืืชื” ืฆืจื™ืš ืœื“ืขืช ืœื ืจืง ื•ืœื ื›ืžื” ื”ืžื•ืฆืจ, ืืœื:

  • ืžืงืจื” ืฉื™ืžื•ืฉ ืฉืœ ื”ื™ื™ืฉื•ื ืฉืœื”;
  • ืฉื™ื˜ื•ืช ืคืจื™ืกื” ืฉื•ื ื•ืช;
  • ื™ืชืจื•ื ื•ืช ื•ื—ืกืจื•ื ื•ืช ืฉืœ ื›ืœ ืฉื™ื˜ื”;
  • ืžื•ืฆืจื™ื ื“ื•ืžื™ื ื•ืืœื˜ืจื ื˜ื™ื‘ื™ื™ื ืœื‘ื—ื™ืจื” ืžื•ืฉื›ืœืช ื•ืื•ืคื˜ื™ืžืœื™ืช ื•ืœื ืชืžื™ื“ ืœื˜ื•ื‘ืช ืžื•ืฆืจ ืžื•ื›ืจ.

ืืชื” ื’ื ืฆืจื™ืš ืœื”ื™ื•ืช ืžืกื•ื’ืœ ืœื”ืขื‘ื™ืจ ื ืชื•ื ื™ื ื•ืœื”ื‘ื™ืŸ ืืช ื”ืขืงืจื•ื ื•ืช ื”ื‘ืกื™ืกื™ื™ื ืฉืœ ืื™ื ื˜ื’ืจืฆื™ื” ืขื ETL.

ืžืงืจื” ืืžื™ืชื™

ื‘ืขื‘ืจ ื”ืœื ืจื—ื•ืง, ื”ื™ื” ืฆื•ืจืš ืœื™ืฆื•ืจ backend ืขื‘ื•ืจ ืืคืœื™ืงืฆื™ื” ืกืœื•ืœืจื™ืช. ืขื“ ืชื—ื™ืœืช ื”ืขื‘ื•ื“ื” ืขืœื™ื•, ื”-backend ื›ื‘ืจ ืคื•ืชื— ื•ื”ื™ื” ืžื•ื›ืŸ ืœื™ื™ืฉื•ื, ื•ืฆื•ื•ืช ื”ืคื™ืชื•ื— ื”ืฉืงื™ืข ื›ืฉื ืชื™ื™ื ื‘ืคืจื•ื™ืงื˜ ื–ื”. ื”ื•ื’ื“ืจื• ื”ืžืฉื™ืžื•ืช ื”ื‘ืื•ืช:

  • ืœื‘ื ื•ืช CI/CD;
  • ืกืงื•ืจ ืืช ื”ืืจื›ื™ื˜ืงื˜ื•ืจื”;
  • ืœื”ื›ื ื™ืก ืืช ื”ื›ืœ ืœืคืขื•ืœื”.

ื”ืืคืœื™ืงืฆื™ื” ืขืฆืžื” ื”ื™ื™ืชื” microservices, ื•ืงื•ื“ Python/Django ืคื•ืชื— ืžืืคืก ื•ื™ืฉื™ืจ ื‘-GCP. ืœื’ื‘ื™ ืงื”ืœ ื”ื™ืขื“, ื”ื”ื ื—ื” ื”ื™ื™ืชื” ืฉื™ื”ื™ื• ืฉื ื™ ืื–ื•ืจื™ื - ืืจื”"ื‘ ื•ื”ืื™ื—ื•ื“ ื”ืื™ืจื•ืคื™, ื•ื”ืชื ื•ืขื” ื”ื•ืคืฆื” ื“ืจืš ืžืื–ืŸ ื”ืขื•ืžืก ื”ืขื•ืœืžื™. ื›ืœ ืขื•ืžืกื™ ื”ืขื‘ื•ื“ื” ื•ืขื•ืžืก ื”ืขื‘ื•ื“ื” ื”ืžื—ืฉื•ื‘ ืคืขืœื• ื‘-Google Kubernetes Engine.

ื‘ืืฉืจ ืœื ืชื•ื ื™ื, ื”ื™ื• 3 ืžื‘ื ื™ื:

  • ืื—ืกื•ืŸ ื‘ืขื ืŸ;
  • ื—ื ื•ืช ืžื™ื“ืข;
  • Cloud SQL (PostgreSQL).

ืื™ืš ืœืฉืจื•ื“ ืžืกื“ ื ืชื•ื ื™ื SQL ื‘ืžืื” ื”-21: ืขื ื ื™ื, Kubernetes ื•-PostgreSQL multimaster

ืืคืฉืจ ืœืชื”ื•ืช ืžื“ื•ืข ื ื‘ื—ืจ Cloud SQL? ืื ืœื•ืžืจ ืืช ื”ืืžืช, ืฉืืœื” ื›ื–ื• ืขื•ืจืจื” ืื™ื–ื•ืฉื”ื™ ื”ืคืกืงื” ืžื‘ื™ื›ื” ื‘ืฉื ื™ื ื”ืื—ืจื•ื ื•ืช - ื™ืฉ ืชื—ื•ืฉื” ืฉืื ืฉื™ื ื”ืชื‘ื™ื™ืฉื• ื‘ืžืื’ืจื™ ืžื™ื“ืข ื™ื—ืกื™ื™ื, ืื‘ืœ ื‘ื›ืœ ื–ืืช ืžืžืฉื™ื›ื™ื ืœื”ืฉืชืžืฉ ื‘ื”ื ื‘ืื•ืคืŸ ืคืขื™ืœ ;-).

ื‘ืืฉืจ ืœืžืงืจื” ืฉืœื ื•, Cloud SQL ื ื‘ื—ืจ ืžื”ืกื™ื‘ื•ืช ื”ื‘ืื•ืช:

  1. ื›ืืžื•ืจ, ื”ืืคืœื™ืงืฆื™ื” ืคื•ืชื—ื” ื‘ืืžืฆืขื•ืช Django, ื•ื™ืฉ ืœื” ืžื•ื“ืœ ืœืžื™ืคื•ื™ ื ืชื•ื ื™ื ืžืชืžื™ื“ื™ื ืžื‘ืกื™ืก ื ืชื•ื ื™ื SQL ืœืื•ื‘ื™ื™ืงื˜ื™ื ืฉืœ Python (Django ORM).
  2. ื”ืžืกื’ืจืช ืขืฆืžื” ืชืžื›ื” ื‘ืจืฉื™ืžื” ื“ื™ ืกื•ืคื™ืช ืฉืœ DBMSs:

  • PostgreSQL;
  • MariaDB;
  • MySQL;
  • ื ื‘ื•ืื”;
  • SQLite.

ื‘ื”ืชืื ืœื›ืš, PostgreSQL ื ื‘ื—ืจื” ืžืชื•ืš ืจืฉื™ืžื” ื–ื• ื‘ืื•ืคืŸ ืื™ื ื˜ื•ืื™ื˜ื™ื‘ื™ ืœืžื“ื™ (ื˜ื•ื‘, ื–ื” ืœื ืื•ืจืงืœ ืœื‘ื—ื•ืจ, ื‘ืืžืช).

ืžื” ื”ื™ื” ื—ืกืจ:

  • ื”ื™ื™ืฉื•ื ื ืคืจืก ืจืง ื‘ืฉื ื™ ืื–ื•ืจื™ื, ื•ืื—ื“ ืฉืœื™ืฉื™ ื”ื•ืคื™ืข ื‘ืชื•ื›ื ื™ื•ืช (ืืกื™ื”);
  • ื‘ืกื™ืก ื”ื ืชื•ื ื™ื ื”ื™ื” ืžืžื•ืงื ื‘ืื–ื•ืจ ืฆืคื•ืŸ ืืžืจื™ืงื” (ืื™ื•ื•ื”);
  • ืžืฆื“ ื”ืœืงื•ื— ื”ื™ื• ื—ืฉืฉื•ืช ืœื’ื‘ื™ ืืคืฉืจื™ ืขื™ื›ื•ื‘ื™ ื’ื™ืฉื” ืžืื™ืจื•ืคื” ื•ืืกื™ื” ื• ื”ืคืจืขื•ืช ื‘ืฉื™ืจื•ืช ื‘ืžืงืจื” ืฉืœ ื”ืฉื‘ืชื” ืฉืœ DBMS.

ืœืžืจื•ืช ื”ืขื•ื‘ื“ื” ืฉ-Django ืขืฆืžื” ื™ื›ื•ืœื” ืœืขื‘ื•ื“ ืขื ืžืกืคืจ ื‘ืกื™ืกื™ ื ืชื•ื ื™ื ื‘ืžืงื‘ื™ืœ ื•ืœื—ืœืง ืื•ืชื ืœืงืจื™ืื” ื•ื›ืชื™ื‘ื”, ืœื ื”ื™ื™ืชื” ื›ืœ ื›ืš ื”ืจื‘ื” ื›ืชื™ื‘ื” ื‘ืืคืœื™ืงืฆื™ื” (ื™ื•ืชืจ ืž-90% ื”ื™ื ืงืจื™ืื”). ื•ื‘ื›ืœืœ, ื•ื‘ื›ืœืœ, ืื ืืคืฉืจ ื”ื™ื” ืœืขืฉื•ืช ืจืคืœื™ืงื” ืฉืœ ื”ื‘ืกื™ืก ื”ืจืืฉื™ ื‘ืื™ืจื•ืคื” ื•ื‘ืืกื™ื”, ื–ื” ื™ื”ื™ื” ืคืชืจื•ืŸ ืคืฉืจื”. ื ื•, ืžื” ื›ืœ ื›ืš ืžืกื•ื‘ืš ื‘ื–ื”?

ื”ืงื•ืฉื™ ื”ื™ื” ืฉื”ืœืงื•ื— ืœื ืจืฆื” ืœื•ื•ืชืจ ืขืœ ืฉื™ืžื•ืฉ ื‘ืฉื™ืจื•ืชื™ื ืžื ื•ื”ืœื™ื ื•ื‘-Cloud SQL. ื•ื”ื™ื›ื•ืœื•ืช ืฉืœ Cloud SQL ืžื•ื’ื‘ืœื•ืช ื›ืจื’ืข. Cloud SQL ืชื•ืžืš ื‘ื–ืžื™ื ื•ืช ื’ื‘ื•ื”ื” (HA) ื•-Replica (RR), ืืš ืื•ืชื• RR ื ืชืžืš ืจืง ื‘ืื–ื•ืจ ืื—ื“. ืœืื—ืจ ืฉื™ืฆืจืช ืžืกื“ ื ืชื•ื ื™ื ื‘ืื–ื•ืจ ืืžืจื™ืงื”, ืื™ื ืš ื™ื›ื•ืœ ืœื™ืฆื•ืจ ื”ืขืชืง ืงืจื™ืื” ื‘ืื–ื•ืจ ืื™ืจื•ืคื” ื‘ืืžืฆืขื•ืช Cloud SQL, ืœืžืจื•ืช ืฉ-Postgres ืขืฆืžื” ืœื ืžื•ื ืขืช ืžืžืš ืœืขืฉื•ืช ื–ืืช. ื”ื”ืชื›ืชื‘ื•ืช ืขื ืขื•ื‘ื“ื™ ื’ื•ื’ืœ ืœื ื”ื•ื‘ื™ืœื” ืœืฉื•ื ืžืงื•ื ื•ื”ืกืชื™ื™ืžื” ื‘ื”ื‘ื˜ื—ื•ืช ื‘ืกื’ื ื•ืŸ "ืื ื—ื ื• ืžื›ื™ืจื™ื ืืช ื”ื‘ืขื™ื” ื•ืขื•ื‘ื“ื™ื ืขืœื™ื”, ืžืชื™ืฉื”ื• ื”ื ื•ืฉื ื™ื™ืคืชืจ".

ืื ื ืจืฉื•ื ื‘ืงืฆืจื” ืืช ื”ื™ื›ื•ืœื•ืช ืฉืœ Cloud SQL, ื–ื” ื™ื™ืจืื” ื‘ืขืจืš ื›ืš:

1. ื–ืžื™ื ื•ืช ื’ื‘ื•ื”ื” (HA):

  • ื‘ืชื•ืš ืื–ื•ืจ ืื—ื“;
  • ื‘ืืžืฆืขื•ืช ืฉื›ืคื•ืœ ื“ื™ืกืง;
  • ืœื ื ืขืฉื” ืฉื™ืžื•ืฉ ื‘ืžื ื•ืขื™ PostgreSQL;
  • ืฉืœื™ื˜ื” ืื•ื˜ื•ืžื˜ื™ืช ื•ื™ื“ื ื™ืช ืืคืฉืจื™ืช - failover/failback;
  • ื‘ืขืช ื”ืžืขื‘ืจ, ื”-DBMS ืื™ื ื• ื–ืžื™ืŸ ืœืžืฉืš ืžืกืคืจ ื“ืงื•ืช.

2. ืงืจื ื”ืขืชืง (RR):

  • ื‘ืชื•ืš ืื–ื•ืจ ืื—ื“;
  • ื”ืžืชื ื” ื—ืžื”;
  • ืฉื›ืคื•ืœ ืกื˜ืจื™ืžื™ื ื’ ืฉืœ PostgreSQL.

ื‘ื ื•ืกืฃ, ื›ืžืงื•ื‘ืœ, ื‘ื‘ื—ื™ืจืช ื˜ื›ื ื•ืœื•ื’ื™ื” ืชืžื™ื“ ืžืชืžื•ื“ื“ื™ื ืขื ื›ืžื” ืžื’ื‘ืœื•ืช:

  • ื”ืœืงื•ื— ืœื ืจืฆื” ืœื™ืฆื•ืจ ื™ืฉื•ื™ื•ืช ื•ืœื”ืฉืชืžืฉ ื‘-IaaS, ืืœื ื‘ืืžืฆืขื•ืช GKE;
  • ื”ืœืงื•ื— ืœื ื™ืจืฆื” ืœืคืจื•ืก ืฉื™ืจื•ืช ืขืฆืžื™ PostgreSQL/MySQL;
  • ื•ื‘ื›ืŸ, ื‘ืื•ืคืŸ ื›ืœืœื™, Google Spanner ื”ื™ื” ืžืชืื™ื ืœืžื“ื™ ืืœืžืœื ื”ืžื—ื™ืจ ืฉืœื•, ืขื ื–ืืช, Django ORM ืœื ื™ื›ื•ืœ ืœืขื‘ื•ื“ ืื™ืชื•, ืื‘ืœ ื–ื” ื“ื‘ืจ ื˜ื•ื‘.

ื‘ื”ืชื—ืฉื‘ ื‘ืžืฆื‘, ื”ืœืงื•ื— ืงื™ื‘ืœ ืฉืืœืช ื”ืžืฉืš: "ื”ืื ืืชื” ื™ื›ื•ืœ ืœืขืฉื•ืช ืžืฉื”ื• ื“ื•ืžื” ื›ื“ื™ ืฉื–ื” ื™ื”ื™ื” ื›ืžื• Google Spanner, ืื‘ืœ ื’ื ื™ืขื‘ื•ื“ ืขื Django ORM?"

ืืคืฉืจื•ืช ืคืชืจื•ืŸ ืžืก' 0

ื”ื“ื‘ืจ ื”ืจืืฉื•ืŸ ืฉืขืœื” ืœื™ ืœืจืืฉ:

  • ื”ื™ืฉืืจ ื‘ืชื•ืš CloudSQL;
  • ืœื ืชื”ื™ื” ืฉื›ืคื•ืœ ืžื•ื‘ื ื” ื‘ื™ืŸ ืื–ื•ืจื™ื ื‘ืฉื•ื ืฆื•ืจื”;
  • ื ืกื” ืœืฆืจืฃ ืขื•ืชืง ืœืขื ืŸ SQL ืงื™ื™ื ืขืœ ื™ื“ื™ PostgreSQL;
  • ื”ืคืขืœ ืžื•ืคืข PostgreSQL ืื™ืคืฉื”ื• ื•ืื™ื›ืฉื”ื•, ืื‘ืœ ืœืคื—ื•ืช ืืœ ืชื™ื’ืข ื‘ืžืืกื˜ืจ.

ืื‘ื•ื™, ื”ืชื‘ืจืจ ืฉืœื ื ื™ืชืŸ ืœืขืฉื•ืช ื–ืืช, ื›ื™ ืื™ืŸ ื’ื™ืฉื” ืœืžืืจื— (ื”ื•ื ื ืžืฆื ื‘ืคืจื•ื™ืงื˜ ืื—ืจ ืœื’ืžืจื™) - pg_hba ื•ื›ืŸ ื”ืœืื”, ื•ืื™ืŸ ื’ื ื’ื™ืฉื” ืชื—ืช superuser.

ืืคืฉืจื•ืช ืคืชืจื•ืŸ ืžืก' 1

ืœืื—ืจ ื”ืจื”ื•ืจ ื ื•ืกืฃ ื•ื”ืชื—ืฉื‘ื•ืช ื‘ื ืกื™ื‘ื•ืช ืงื•ื“ืžื•ืช, ื”ืฉืชื ืชื” ืžืกืœื•ืœ ื”ืžื—ืฉื‘ื” ื‘ืžืงืฆืช:

  • ืื ื—ื ื• ืขื“ื™ื™ืŸ ืžื ืกื™ื ืœื”ื™ืฉืืจ ื‘ืชื•ืš CloudSQL, ืื‘ืœ ืื ื—ื ื• ืขื•ื‘ืจื™ื ืœ-MySQL, ื›ื™ ืœ-Cloud SQL ืฉืœ โ€‹โ€‹MySQL ื™ืฉ ืžืืกื˜ืจ ื—ื™ืฆื•ื ื™, ืืฉืจ:

- ื”ื•ื ืคืจื•ืงืกื™ ืขื‘ื•ืจ MySQL ื—ื™ืฆื•ื ื™;
- ื ืจืื” ื›ืžื• ืžื•ืคืข MySQL;
- ื”ื•ืžืฆื ืœื”ืขื‘ืจืช ื ืชื•ื ื™ื ืžืขื ื ื™ื ืื—ืจื™ื ืื• ืžืงื•ืžื™ื™ื.

ืžื›ื™ื•ื•ืŸ ืฉื”ื’ื“ืจืช ืจืคืœื™ืงืฆื™ื™ืช MySQL ืื™ื ื” ื“ื•ืจืฉืช ื’ื™ืฉื” ืœืžืืจื—, ื‘ืื•ืคืŸ ืขืงืจื•ื ื™ ื”ื›ืœ ืขื‘ื“, ืื‘ืœ ื–ื” ื”ื™ื” ืžืื•ื“ ืœื ื™ืฆื™ื‘ ื•ืœื ื ื•ื—. ื•ื›ืฉื”ืœื›ื ื• ืจื—ื•ืง ื™ื•ืชืจ, ื–ื” ื ื”ื™ื” ืžืคื—ื™ื“ ืœื’ืžืจื™, ื›ื™ ืคืจืกื ื• ืืช ื›ืœ ื”ืžื‘ื ื” ื‘ื˜ืจืคื•ืจื, ื•ืคืชืื•ื ื”ืชื‘ืจืจ ืฉื”ืžืืกื˜ืจ ื”ื—ื™ืฆื•ื ื™ ืœื ื ืชืžืš ื‘ื˜ืจืคื•ืจื. ื›ืŸ, ืœื’ื•ื’ืœ ื™ืฉ CLI, ืื‘ืœ ืžืฉื•ื ืžื” ื”ื›ืœ ืขื‘ื“ ื›ืืŸ ืžื“ื™ ืคืขื - ืœืคืขืžื™ื ื–ื” ื ื•ืฆืจ, ืœืคืขืžื™ื ื–ื” ืœื ื ื•ืฆืจ. ืื•ืœื™ ื‘ื’ืœืœ ืฉื”-CLI ื”ื•ืžืฆื ืขื‘ื•ืจ ื”ืขื‘ืจืช ื ืชื•ื ื™ื ื—ื™ืฆื•ื ื™ืช, ื•ืœื ืขื‘ื•ืจ ื”ืขืชืงื™ื.

ืœืžืขืฉื”, ื‘ืฉืœื‘ ื–ื” ื”ืชื‘ืจืจ ืฉ-Cloud SQL ืื™ื ื• ืžืชืื™ื ื›ืœืœ. ื›ืžื• ืฉืื•ืžืจื™ื, ืขืฉื™ื ื• ื›ืœ ืžื” ืฉื™ื›ื•ืœื ื•.

ืืคืฉืจื•ืช ืคืชืจื•ืŸ ืžืก' 2

ืžื›ื™ื•ื•ืŸ ืฉืœื ื ื™ืชืŸ ื”ื™ื” ืœื”ื™ืฉืืจ ื‘ืžืกื’ืจืช Cloud SQL, ื ื™ืกื™ื ื• ืœื’ื‘ืฉ ื“ืจื™ืฉื•ืช ืœืคืชืจื•ืŸ ืคืฉืจื”. ื”ื“ืจื™ืฉื•ืช ื”ืชื‘ืจืจื• ื›ื“ืœืงืžืŸ:

  • ืขื‘ื•ื“ื” ื‘-Kubernetes, ืฉื™ืžื•ืฉ ืžืจื‘ื™ ื‘ืžืฉืื‘ื™ื ื•ื‘ื™ื›ื•ืœื•ืช ืฉืœ Kubernetes (DCS, ...) ื•- GCP (LB, ...);
  • ื—ื•ืกืจ ื‘ื ื˜ืœ ืžื—ื‘ื•ืจื” ืฉืœ ื“ื‘ืจื™ื ืžื™ื•ืชืจื™ื ื‘ืขื ืŸ ื›ืžื• ืคืจื•ืงืกื™ HA;
  • ื”ื™ื›ื•ืœืช ืœื”ืจื™ืฅ PostgreSQL ืื• MySQL ื‘ืื–ื•ืจ HA ื”ืจืืฉื™; ื‘ืื–ื•ืจื™ื ืื—ืจื™ื - HA ืžื”-RR ืฉืœ ื”ืื–ื•ืจ ื”ืจืืฉื™ ื‘ืชื•ืกืคืช ื”ืขื•ืชืง ืฉืœื• (ืœืžืขืŸ ืžื”ื™ืžื ื•ืช);
  • ืžื•ืœื˜ื™ ืžืืกื˜ืจ (ืœื ืจืฆื™ืชื™ ืœื™ืฆื•ืจ ืื™ืชื• ืงืฉืจ, ืื‘ืœ ื–ื” ืœื ื”ื™ื” ืžืื•ื“ ื—ืฉื•ื‘)

.
ื›ืชื•ืฆืื” ืžื“ืจื™ืฉื•ืช ืืœื•, ืขืž'DBMS ืžืชืื™ื ื•ืืคืฉืจื•ื™ื•ืช ื›ืจื™ื›ื”:

  • MySQL Galera;
  • CockroachDB;
  • ื›ืœื™ PostgreSQL

:
- pgpool-II;
- ืคื˜ืจื•ื ื™.

MySQL Galera

ื˜ื›ื ื•ืœื•ื’ื™ื™ืช MySQL Galera ืคื•ืชื—ื” ืขืœ ื™ื“ื™ Codership ื•ื”ื™ื ืชื•ืกืฃ ืขื‘ื•ืจ InnoDB. ืžื•ื–ืจื•ื™ื•ืช:

  • ืจื‘ ืžืืกื˜ืจ;
  • ืฉื›ืคื•ืœ ืกื™ื ื›ืจื•ื ื™;
  • ืงืจื™ืื” ืžื›ืœ ืฆื•ืžืช;
  • ื”ืงืœื˜ื” ืœื›ืœ ืฆื•ืžืช;
  • ืžื ื’ื ื•ืŸ HA ืžื•ื‘ื ื”;
  • ื™ืฉ ืชืจืฉื™ื Helm ืžื‘ื™ื˜ื ืืžื™.

ื’'ื•ืง DB

ืœืคื™ ื”ืชื™ืื•ืจ, ื”ื“ื‘ืจ ื”ื•ื ืคืฆืฆื” ืœื—ืœื•ื˜ื™ืŸ ื•ื”ื•ื ืคืจื•ื™ืงื˜ ืงื•ื“ ืคืชื•ื— ืฉื ื›ืชื‘ ื‘-Go. ื”ืžืฉืชืชืฃ ื”ืขื™ืงืจื™ ื”ื•ื Cockroach Labs (ื ื•ืกื“ื” ืขืœ ื™ื“ื™ ืื ืฉื™ื ืžื’ื•ื’ืœ). DBMS ื™ื—ืกื™ ื–ื” ืชื•ื›ื ืŸ ื‘ืžืงื•ืจ ืœื”ื™ื•ืช ืžื•ืคืฅ (ืขื ืงื ื” ืžื™ื“ื” ืื•ืคืงื™ ืžื—ื•ืฅ ืœืงื•ืคืกื”) ื•ืกื•ื‘ืœื ื™ ืœืชืงืœื•ืช. ืžื—ื‘ืจื™ื” ืžื”ื—ื‘ืจื” ืชื™ืืจื• ืืช ื”ืžื˜ืจื” ืฉืœ "ืœืฉืœื‘ ืืช ื”ืขื•ืฉืจ ืฉืœ ืคื•ื ืงืฆื™ื•ื ืœื™ื•ืช SQL ืขื ื”ื ื’ื™ืฉื•ืช ื”ืื•ืคืงื™ืช ื”ืžื•ื›ืจืช ืœืคืชืจื•ื ื•ืช NoSQL."

ื‘ื•ื ื•ืก ื ื—ืžื“ ื”ื•ื ืชืžื™ื›ื” ื‘ืคืจื•ื˜ื•ืงื•ืœ ื”ื—ื™ื‘ื•ืจ ืฉืœืื—ืจ ื”ืชืงื“ืžื•ืช.

Pgpool

ื–ื”ื• ืชื•ืกืคืช ืœ-PostgreSQL, ืœืžืขืฉื”, ื™ืฉื•ืช ื—ื“ืฉื” ืฉืžืฉืชืœื˜ืช ืขืœ ื›ืœ ื”ื—ื™ื‘ื•ืจื™ื ื•ืžืขื‘ื“ืช ืื•ืชื. ื™ืฉ ืœื• ืžืื–ืŸ ืขื•ืžืกื™ื ื•ืžื ืชื— ืžืฉืœื•, ื‘ืจื™ืฉื™ื•ืŸ ืชื—ืช ืจื™ืฉื™ื•ืŸ BSD. ื–ื” ืžืกืคืง ื”ื–ื“ืžื ื•ื™ื•ืช ื‘ืฉืคืข, ืื‘ืœ ื ืจืื” ืงืฆืช ืžืคื—ื™ื“, ื›ื™ ื”ื ื•ื›ื—ื•ืช ืฉืœ ื™ืฉื•ืช ื—ื“ืฉื” ืขืœื•ืœื” ืœื”ืคื•ืš ืœืžืงื•ืจ ืœื›ืžื” ื”ืจืคืชืงืื•ืช ื ื•ืกืคื•ืช.

ืคื˜ืจื•ื ื™

ื–ื” ื”ื“ื‘ืจ ื”ืื—ืจื•ืŸ ืฉืขื™ื ื™ื™ ื ืคืœื• ืขืœื™ื•, ื•ื›ืคื™ ืฉื”ืชื‘ืจืจ, ืœื ื‘ื›ื“ื™. Patroni ื”ื•ื ื›ืœื™ ืขื–ืจ ื‘ืงื•ื“ ืคืชื•ื—, ืฉื”ื•ื ื‘ืขืฆื ื“ืžื•ืŸ Python ื”ืžืืคืฉืจ ืœืš ืœืชื—ื–ืง ืื•ื˜ื•ืžื˜ื™ืช ืืฉื›ื•ืœื•ืช PostgreSQL ืขื ืกื•ื’ื™ื ืฉื•ื ื™ื ืฉืœ ืฉื›ืคื•ืœ ื•ื”ื—ืœืคืช ืชืคืงื™ื“ื™ื ืื•ื˜ื•ืžื˜ื™ืช. ื”ื“ื‘ืจ ื”ืชื‘ืจืจ ื›ืžืขื ื™ื™ืŸ ืžืื•ื“, ืžื›ื™ื•ื•ืŸ ืฉื”ื•ื ืžืฉืชืœื‘ ื”ื™ื˜ื‘ ืขื ื”-cuber ื•ืื™ื ื• ืžืฆื™ื’ ื™ืฉื•ื™ื•ืช ื—ื“ืฉื•ืช.

ืžื” ื‘ื—ืจืช ื‘ืกื•ืฃ?

ื”ื‘ื—ื™ืจื” ืœื ื”ื™ื™ืชื” ืงืœื”:

  1. ื’'ื•ืง DB - ืืฉ, ืื‘ืœ ื—ืฉื•ืš;
  2. MySQL Galera - ื’ื ืœื ืจืข, ืžืฉืชืžืฉื™ื ื‘ื• ื‘ื”ืจื‘ื” ืžืงื•ืžื•ืช, ืื‘ืœ MySQL;
  3. Pgpool - ื”ืจื‘ื” ื™ืฉื•ื™ื•ืช ืžื™ื•ืชืจื•ืช, ื›ืœ ื›ืš ืื™ื ื˜ื’ืจืฆื™ื” ืขื ื”ืขื ืŸ ื•-K8s;
  4. ืคื˜ืจื•ื ื™ - ืื™ื ื˜ื’ืจืฆื™ื” ืžืขื•ืœื” ืขื K8s, ืœืœื ื™ืฉื•ื™ื•ืช ืžื™ื•ืชืจื•ืช, ืžืฉืชืœื‘ ื”ื™ื˜ื‘ ืขื GCP LB.

ืœืคื™ื›ืš, ื”ื‘ื—ื™ืจื” ื ืคืœื” ืขืœ ืคื˜ืจื•ื ื™.

ืžืžืฆืื™ื

ื”ื’ื™ืข ื”ื–ืžืŸ ืœืกื›ื ื‘ืงืฆืจื”. ื›ืŸ, ืขื•ืœื ืชืฉืชื™ื•ืช ื”-IT ื”ืฉืชื ื” ื‘ืื•ืคืŸ ืžืฉืžืขื•ืชื™, ื•ื–ื• ืจืง ื”ื”ืชื—ืœื”. ื•ืื ืœืคื ื™ ื›ืŸ ื”ืขื ื ื™ื ื”ื™ื• ืจืง ืขื•ื“ ืกื•ื’ ืฉืœ ืชืฉืชื™ืช, ืขื›ืฉื™ื• ื”ื›ืœ ืฉื•ื ื”. ื™ืชืจื” ืžื›ืš, ื›ืœ ื”ื–ืžืŸ ืžื•ืคื™ืขื™ื ื—ื™ื“ื•ืฉื™ื ื‘ืขื ื ื™ื, ื”ื ื™ื•ืคื™ืขื• ื•ืื•ืœื™ ื™ื•ืคื™ืขื• ืจืง ื‘ืขื ื ื™ื ื•ืจืง ืื–, ื‘ืžืืžืฆื™ื ืฉืœ ืกื˜ืืจื˜ืืคื™ื, ื”ื ื™ื•ืขื‘ืจื• ืœ-On-premises.

ืœื’ื‘ื™ SQL, SQL ื™ื—ื™ื”. ื–ื” ืื•ืžืจ ืฉืืชื” ืฆืจื™ืš ืœื”ื›ื™ืจ ืืช PostgreSQL ื•-MySQL ื•ืœื”ื™ื•ืช ืžืกื•ื’ืœ ืœืขื‘ื•ื“ ืื™ืชื, ืื‘ืœ ืขื•ื“ ื™ื•ืชืจ ื—ืฉื•ื‘ ื–ื” ืœื”ื™ื•ืช ืžืกื•ื’ืœ ืœื”ืฉืชืžืฉ ื‘ื”ื ื‘ืฆื•ืจื” ื ื›ื•ื ื”.

ืžืงื•ืจ: www.habr.com

ื”ื•ืกืคืช ืชื’ื•ื‘ื”