mirror of
https://github.com/ltcptgeneral/cs239-caching.git
synced 2025-04-04 05:23:26 +00:00
add time stamp (in ms) to get response
This commit is contained in:
parent
ea88a0649c
commit
44dbf976b5
@ -4,6 +4,7 @@ from cache.cache import BaselineCache
|
|||||||
from cache.prefetch_cache import PrefetchCache
|
from cache.prefetch_cache import PrefetchCache
|
||||||
from cache.tiered_cache import TieredCache
|
from cache.tiered_cache import TieredCache
|
||||||
from config import CACHE_STRATEGY, CACHE_LIMIT, L2_CACHE_LIMIT
|
from config import CACHE_STRATEGY, CACHE_LIMIT, L2_CACHE_LIMIT
|
||||||
|
import time
|
||||||
|
|
||||||
app = FastAPI()
|
app = FastAPI()
|
||||||
|
|
||||||
@ -20,16 +21,17 @@ else:
|
|||||||
@app.get("/user/{user_id}")
|
@app.get("/user/{user_id}")
|
||||||
def fetch_user_profile(user_id: str):
|
def fetch_user_profile(user_id: str):
|
||||||
"""Fetch user profile with caching"""
|
"""Fetch user profile with caching"""
|
||||||
|
start = time.time()
|
||||||
cached_profile = cache.get(user_id)
|
cached_profile = cache.get(user_id)
|
||||||
if cached_profile:
|
if cached_profile:
|
||||||
return {"user_id": user_id, "profile": cached_profile, "source": "cache"}
|
return {"user_id": user_id, "profile": cached_profile, "source": "cache", "time_ms": (time.time() - start) * 1000}
|
||||||
|
|
||||||
profile = get_user_profile(user_id)
|
profile = get_user_profile(user_id)
|
||||||
if profile is None:
|
if profile is None:
|
||||||
raise HTTPException(status_code=404, detail="User not found")
|
raise HTTPException(status_code=404, detail="User not found")
|
||||||
|
|
||||||
cache.put(user_id, profile) # Store in cache
|
cache.put(user_id, profile) # Store in cache
|
||||||
return {"user_id": user_id, "profile": profile, "source": "database"}
|
return {"user_id": user_id, "profile": profile, "source": "database", "time_ms": (time.time() - start) * 1000}
|
||||||
|
|
||||||
@app.post("/update_user/")
|
@app.post("/update_user/")
|
||||||
def modify_user_profile(user_id: str, name: str, followers: int, bio: str, posts: str):
|
def modify_user_profile(user_id: str, name: str, followers: int, bio: str, posts: str):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user