mirror of
https://github.com/neondatabase/neon.git
synced 2026-05-28 18:40:38 +00:00
We use the term "endpoint" in for compute Postgres nodes in the web UI
and user-facing documentation now. Adjust the nomenclature in the code.
This changes the name of the "neon_local pg" command to "neon_local
endpoint". Also adjust names of classes, variables etc. in the python
tests accordingly.
This also changes the directory structure so that endpoints are now
stored in:
.neon/endpoints/<endpoint id>
instead of:
.neon/pgdatadirs/tenants/<tenant_id>/<endpoint (node) name>
The tenant ID is no longer part of the path. That means that you
cannot have two endpoints with the same name/ID in two different
tenants anymore. That's consistent with how we treat endpoints in the
real control plane and proxy: the endpoint ID must be globally unique.
41 lines
1.4 KiB
Python
41 lines
1.4 KiB
Python
# This test spawns pgbench in a thread in the background and concurrently restarts pageserver,
|
|
# checking how client is able to transparently restore connection to pageserver
|
|
#
|
|
import threading
|
|
import time
|
|
|
|
from fixtures.log_helper import log
|
|
from fixtures.neon_fixtures import NeonEnv, PgBin
|
|
|
|
|
|
# Test restarting page server, while safekeeper and compute node keep
|
|
# running.
|
|
def test_pageserver_restarts_under_worload(neon_simple_env: NeonEnv, pg_bin: PgBin):
|
|
env = neon_simple_env
|
|
env.neon_cli.create_branch("test_pageserver_restarts")
|
|
endpoint = env.endpoints.create_start("test_pageserver_restarts")
|
|
n_restarts = 10
|
|
scale = 10
|
|
|
|
# the background task may complete the init task delay after finding an
|
|
# active tenant, but shutdown starts right before Tenant::gc_iteration
|
|
env.pageserver.allowed_errors.append(
|
|
r".*Gc failed, retrying in \S+: Cannot run GC iteration on inactive tenant"
|
|
)
|
|
|
|
def run_pgbench(connstr: str):
|
|
log.info(f"Start a pgbench workload on pg {connstr}")
|
|
pg_bin.run_capture(["pgbench", "-i", f"-s{scale}", connstr])
|
|
pg_bin.run_capture(["pgbench", f"-T{n_restarts}", connstr])
|
|
|
|
thread = threading.Thread(target=run_pgbench, args=(endpoint.connstr(),), daemon=True)
|
|
thread.start()
|
|
|
|
for i in range(n_restarts):
|
|
# Stop the pageserver gracefully and restart it.
|
|
time.sleep(1)
|
|
env.pageserver.stop()
|
|
env.pageserver.start()
|
|
|
|
thread.join()
|