Skip to content

Latest commit

 

History

History
172 lines (142 loc) · 5.8 KB

notable-uncategorized.md

File metadata and controls

172 lines (142 loc) · 5.8 KB

Notable materials grab-bag

Content

Pieter Hintjens philosophy

Pieter Hintjens - his speeches are pure gold. Love his philosophy

Plugin Oriented Programming

Plugin Oriented Programming book

  • anti monolithic design
  • Write programs that do one thing and do it well
  • Write programs to work together
  • Write programs to expose interfaces that can be easily merged together

Netflix Guide to Microservices

Mastering Chaos - A Netflix Guide to Microservices

  • cool insights on monolithic patterns in distributed infra
  • keywords:
    • cascading failure
    • fault injection testing
    • identifying critical microservices in ecosystem
    • bare bone REST vs client libraries
    • CAP theorem; eventual consistency
    • multi region strategy
    • stateless service (pets vs cattle)
    • cache patterns and anti patterns (EVCache + solutions)
    • "production ready" checklist
    • polyglot & containers (the paved road vs off-road) -> cost of variance
    • velocity with confidence
    • Conway's law -> solution's first, team second

Command-query Separation

7 Reasons why your microservices should use Event Sourcing & CQRS - Hugh McKee

  • System of loosely coupled services
    1. independently deployable
    2. owns its schema
    3. API only access to data
  • 7 Reasons why to use Event Sourcing & CQRS:
    1. smooth transition from DDD & event storming to implementation
    2. reduce service coupling
    3. break the read vs write performance bottleneck
    4. elevate the concurrency barrier
    5. simplify and harden messaging
    6. eliminate service coupling
    7. graduate from IT nursery

Patterns of Effective Teams

GOTO 2017 • Patterns of Effective Teams • Dan North

API first

Kubernetes random

PostgreSQL

BEGIN;

-- #1 rename the huge table and its indices
ALTER TABLE foo RENAME TO foo_legacy;
ALTER INDEX foo_id RENAME TO foo_legacy_id;

-- #2 create empty partitioned table & indices
CREATE TABLE foo (
    id uuid NOT NULL,
    date timestamptz NOT NULL
) PARTITION BY RANGE (date);
CREATE INDEX foo_id ON foo(id);

-- #3 create partition for new incoming data
CREATE TABLE foo_y2023m01 PARTITION OF foo
FOR VALUES FROM ('2023-01-01') TO ('2023-02-01');

-- magic
-- #4 attach old table as a partition
DO $$
DECLARE earliest timestamptz;
DECLARE latest timestamptz;
BEGIN

SELECT min(date) INTO earliest FROM foo_legacy;
latest := '2023-01-01'::timestamptz;

-- HACK (only because we know and trust our data)
ALTER TABLE foo_legacy
ADD CONSTRAINT foo_legacy_date
CHECK (date >= earliest AND date < latest)
NOT VALID;

UPDATE pg_constraint
SET convalidated = true
WHERE conname = 'foo_legacy_date';
-- end of HACK

ALTER TABLE foo
ATTACH PARTITION foo_legacy
FOR VALUES FROM (earliest) TO (latest);

END
$$ LANGUAGE PLPGSQL;
COMMIT;

then e.g.during less busy hours

-- #5 move date into new table at our own pace
CREATE TABLE foo_y2021 PARTITION OF foo
FOR VALUES FROM ('2021-01-01') TO ('2022-01-01');

WITH rows AS (
    DELETE FROM foo_legacy f
    WHERE (date >= '2021-01-01' AND date < '2022-01-01')
    RETURNING f.*
) INSERT INTO foo SELECT * FROM rows;

CREATE TABLE foo_y2022 PARTITION OF foo
FOR VALUES FROM ('2022-01-01') TO ('2023-01-01');

WITH rows AS (
    DELETE FROM foo_legacy f
    WHERE (date >= '2022-01-01' AND date < '2023-01-01')
    RETURNING f.*
) INSERT INTO foo SELECT * FROM rows;