晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
| DIR:/opt/cloudlinux/venv/lib64/python3.11/site-packages/lvestats/lib/bursting/ |
| Current File : //opt/cloudlinux/venv/lib64/python3.11/site-packages/lvestats/lib/bursting/history.py |
# coding=utf-8
#
# Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2023 All Rights Reserved
#
# Licensed under CLOUD LINUX LICENSE AGREEMENT
# http://cloudlinux.com/docs/LICENSE.TXT
import datetime
import sqlalchemy as sa
from lvestats.orm import bursting_events_table
class TableDoesNotExistError(Exception):
def __init__(self, table_name):
self.message = f'Table "{table_name}" does not exist in the database'
super().__init__(self.message)
class HistoryShowBursting:
def __init__(self,
dbengine: sa.engine.base.Engine,
period_from: datetime.datetime,
period_to: datetime.datetime,
uid: int | None = None,
server_id: str = 'localhost') -> None:
self.dbengine = dbengine
self.period_from = period_from
self.period_to = period_to
self.uid = uid
self.server_id = server_id
def get(self) -> list[sa.engine.RowProxy]:
"""
Get history from the 'bursting_events' table.
Retrieving records within the required time frame,
along with one record preceding this time frame
to detect the bursting status at the start of the time frame.
"""
# Since bursting limits functionality isn't enabled by default,
# we need to check if the table exists first
inspector = sa.inspect(self.dbengine)
if bursting_events_table.name not in inspector.get_table_names():
raise TableDoesNotExistError(bursting_events_table.name)
ts_from = self.period_from.timestamp()
ts_to = self.period_to.timestamp()
# Get the rows with timestamp between ts_from and ts_to
stmt1 = sa.select([
bursting_events_table.c.lve_id,
bursting_events_table.c.timestamp,
bursting_events_table.c.event_type,
]).where(
sa.and_(
bursting_events_table.c.server_id == self.server_id,
bursting_events_table.c.timestamp >= ts_from,
bursting_events_table.c.timestamp <= ts_to,
# Add lve_id condition if it's specified
(bursting_events_table.c.lve_id == self.uid) if self.uid is not None else True,
)
)
# Subquery to get the maximum timestamp for each lve_id where timestamp < ts_from
subquery = sa.select([
bursting_events_table.c.lve_id,
sa.func.max(bursting_events_table.c.timestamp).label('max_timestamp'),
]).where(
sa.and_(
bursting_events_table.c.server_id == self.server_id,
bursting_events_table.c.timestamp < ts_from,
# Add lve_id condition if it's specified
(bursting_events_table.c.lve_id == self.uid) if self.uid is not None else True,
)
).group_by(
bursting_events_table.c.lve_id,
).alias('subquery')
# Get the row with the maximum timestamp less than ts_from
stmt2 = sa.select([
bursting_events_table.c.lve_id,
bursting_events_table.c.timestamp,
bursting_events_table.c.event_type,
]).select_from(
bursting_events_table.join(
subquery,
sa.and_(
bursting_events_table.c.lve_id == subquery.c.lve_id,
bursting_events_table.c.timestamp == subquery.c.max_timestamp,
)
)
)
stmt = sa.union(
stmt1,
stmt2,
)
stmt = stmt.order_by(
stmt.c.lve_id,
stmt.c.timestamp,
)
with self.dbengine.connect() as connection:
result = connection.execute(stmt).fetchall()
return result
|