From 3b86375782393248fa430f6d03f4c6e00e239c2b Mon Sep 17 00:00:00 2001 From: Daniel Chico Date: Thu, 7 Mar 2024 12:26:03 -0500 Subject: [PATCH 01/74] feat: add realease details to discord notification message --- .github/workflows/ghcr_deploy.yml | 24 ++++++++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/.github/workflows/ghcr_deploy.yml b/.github/workflows/ghcr_deploy.yml index a367ae2b8..d7cf4271c 100644 --- a/.github/workflows/ghcr_deploy.yml +++ b/.github/workflows/ghcr_deploy.yml @@ -146,9 +146,29 @@ jobs: } catch (error) { core.setFailed(error.message); } + - name: Fetch Release Notes + id: release-notes + uses: actions/github-script@v6 + with: + github-token: "${{ secrets.GITHUB_TOKEN }}" + script: | + try { + const response = await github.rest.repos.getRelease({ + owner: context.repo.owner, + repo: context.repo.repo, + release_id: process.env.RELEASE_ID, + }); + return response.data.body; + } catch (error) { + core.setFailed(error.message); + } + env: + RELEASE_ID: ${{ env.RELEASE_ID }} - name: Github Releases To Discord env: WEBHOOK_URL: ${{ secrets.WEBHOOK_URL }} + REALEASE_TAG: ${{ env.RELEASE_TAG }} + RELEASE_NOTES: ${{ steps.release-notes.outputs.result }} run: | curl -H "Content-Type: application/json" -X POST -d '{ "content": "||@everyone||", @@ -156,8 +176,8 @@ jobs: "avatar_url": "https://cdn.discordapp.com/avatars/487431320314576937/bd64361e4ba6313d561d54e78c9e7171.png", "embeds": [ { - "title": "Changelog", - "description": "This is the changelog for the latest release.", + "title": "Changelog for ${RELEASE_TAG}", + "description": "${RELEASE_NOTES}", "color": 2105893 } ] From 3baa55210a890e11ba91122b52cfbcb1848fd6f8 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 12:22:39 -0800 Subject: [PATCH 02/74] (docs) setting load balancing config --- docs/my-website/docs/proxy/configs.md | 31 +++++++++++++++++++++++---- 1 file changed, 27 insertions(+), 4 deletions(-) diff --git a/docs/my-website/docs/proxy/configs.md b/docs/my-website/docs/proxy/configs.md index 2b3edfadb..5745685de 100644 --- a/docs/my-website/docs/proxy/configs.md +++ b/docs/my-website/docs/proxy/configs.md @@ -248,31 +248,46 @@ $ litellm --config /path/to/config.yaml Use this to call multiple instances of the same model and configure things like [routing strategy](../routing.md#advanced). -```yaml -router_settings: - routing_strategy: "latency-based-routing" # routes to the fastest deployment in the group +For optimal performance: +- Set `tpm/rpm` per model deployment. Weighted picks are then based on the established tpm/rpm. +- Select your optimal routing strategy in `router_settings:routing_strategy`. +LiteLLM supports +```python +["simple-shuffle", "least-busy", "usage-based-routing","latency-based-routing"], default="simple-shuffle"` +``` + +When `tpm/rpm` is set + `routing_strategy==simple-shuffle` litellm will use a weighted pick based on set tpm/rpm. **In our load tests setting tpm/rpm for all deployments + `routing_strategy==simple-shuffle` maximized throughput** +- When using multiple LiteLLM Servers / Kubernetes set redis settings `router_settings:redis_host` etc + +```yaml model_list: - model_name: zephyr-beta litellm_params: model: huggingface/HuggingFaceH4/zephyr-7b-beta api_base: http://0.0.0.0:8001 + rpm: 60 # Optional[int]: When rpm/tpm set - litellm uses weighted pick for load balancing. rpm = Rate limit for this deployment: in requests per minute (rpm). + tpm: 1000 # Optional[int]: tpm = Tokens Per Minute - model_name: zephyr-beta litellm_params: model: huggingface/HuggingFaceH4/zephyr-7b-beta api_base: http://0.0.0.0:8002 + rpm: 600 - model_name: zephyr-beta litellm_params: model: huggingface/HuggingFaceH4/zephyr-7b-beta api_base: http://0.0.0.0:8003 + rpm: 60000 - model_name: gpt-3.5-turbo litellm_params: model: gpt-3.5-turbo api_key: + rpm: 200 - model_name: gpt-3.5-turbo-16k litellm_params: model: gpt-3.5-turbo-16k api_key: + rpm: 100 litellm_settings: num_retries: 3 # retry call 3 times on each model_name (e.g. zephyr-beta) @@ -280,8 +295,16 @@ litellm_settings: fallbacks: [{"zephyr-beta": ["gpt-3.5-turbo"]}] # fallback to gpt-3.5-turbo if call fails num_retries context_window_fallbacks: [{"zephyr-beta": ["gpt-3.5-turbo-16k"]}, {"gpt-3.5-turbo": ["gpt-3.5-turbo-16k"]}] # fallback to gpt-3.5-turbo-16k if context window error allowed_fails: 3 # cooldown model if it fails > 1 call in a minute. -``` +router_settings: # router_settings are optional + routing_strategy: simple-shuffle # Literal["simple-shuffle", "least-busy", "usage-based-routing","latency-based-routing"], default="simple-shuffle" + model_group_alias: {"gpt-4": "gpt-3.5-turbo"} # all requests with `gpt-4` will be routed to models with `gpt-3.5-turbo` + num_retries: 2 + timeout: 30 # 30 seconds + redis_host: # set this when using multiple litellm proxy deployments, load balancing state stored in redis + redis_password: + redis_port: 1992 +``` ## Set Azure `base_model` for cost tracking From b64e4c3e6ff8f1d6e26896bb6367097ac9215378 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 13:42:54 -0800 Subject: [PATCH 03/74] (feat) better debugging when reading prisma --- litellm/proxy/utils.py | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/litellm/proxy/utils.py b/litellm/proxy/utils.py index 81130787d..26ed35604 100644 --- a/litellm/proxy/utils.py +++ b/litellm/proxy/utils.py @@ -693,6 +693,9 @@ class PrismaClient: """ Generic implementation of get data """ + verbose_proxy_logger.debug( + f"PrismaClient: get_generic_data: {key}, table_name: {table_name}" + ) try: if table_name == "users": response = await self.db.litellm_usertable.find_first( @@ -758,6 +761,9 @@ class PrismaClient: int ] = None, # pagination, number of rows to getch when find_all==True ): + verbose_proxy_logger.debug( + f"PrismaClient: get_data: table_name: {table_name}, query_type: {query_type}, user_id: {user_id}, user_id_list: {user_id_list}, team_id: {team_id}, team_id_list: {team_id_list}, key_val: {key_val}" + ) try: response: Any = None if (token is not None and table_name is None) or ( @@ -1020,6 +1026,7 @@ class PrismaClient: Add a key to the database. If it already exists, do nothing. """ try: + verbose_proxy_logger.debug(f"PrismaClient: insert_data: {data}") if table_name == "key": token = data["token"] hashed_token = self.hash_token(token=token) @@ -1152,6 +1159,9 @@ class PrismaClient: """ Update existing data """ + verbose_proxy_logger.debug( + f"PrismaClient: update_data, table_name: {table_name}" + ) try: db_data = self.jsonify_object(data=data) if update_key_values is not None: From 5217e800c4ba6c5d4884983dd1e12c277e98673f Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 14:04:02 -0800 Subject: [PATCH 04/74] (fix) better prisma debug logs --- litellm/proxy/utils.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/litellm/proxy/utils.py b/litellm/proxy/utils.py index 26ed35604..0f0097ff6 100644 --- a/litellm/proxy/utils.py +++ b/litellm/proxy/utils.py @@ -762,7 +762,7 @@ class PrismaClient: ] = None, # pagination, number of rows to getch when find_all==True ): verbose_proxy_logger.debug( - f"PrismaClient: get_data: table_name: {table_name}, query_type: {query_type}, user_id: {user_id}, user_id_list: {user_id_list}, team_id: {team_id}, team_id_list: {team_id_list}, key_val: {key_val}" + f"PrismaClient: get_data: token={token}, table_name: {table_name}, query_type: {query_type}, user_id: {user_id}, user_id_list: {user_id_list}, team_id: {team_id}, team_id_list: {team_id_list}, key_val: {key_val}" ) try: response: Any = None From 8c3ec15856d87d3689bd87f86bc485f711ade8a0 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 15:44:03 -0800 Subject: [PATCH 05/74] (fix) improve improve prisma alerting/debug --- litellm/proxy/utils.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/litellm/proxy/utils.py b/litellm/proxy/utils.py index 0f0097ff6..32f799360 100644 --- a/litellm/proxy/utils.py +++ b/litellm/proxy/utils.py @@ -997,9 +997,11 @@ class PrismaClient: except Exception as e: import traceback - error_msg = f"LiteLLM Prisma Client Exception get_data: {str(e)}" + prisma_query_info = f"LiteLLM Prisma Client Exception: get_data: token={token}, table_name: {table_name}, query_type: {query_type}, user_id: {user_id}, user_id_list: {user_id_list}, team_id: {team_id}, team_id_list: {team_id_list}, key_val: {key_val}" + error_msg = prisma_query_info + str(e) print_verbose(error_msg) error_traceback = error_msg + "\n" + traceback.format_exc() + verbose_proxy_logger.debug(error_traceback) asyncio.create_task( self.proxy_logging_obj.failure_handler( original_exception=e, traceback_str=error_traceback From dec967f647bd3d865383f011b82275491ce3ba36 Mon Sep 17 00:00:00 2001 From: Krish Dholakia Date: Thu, 7 Mar 2024 16:31:23 -0800 Subject: [PATCH 06/74] Update model_prices_and_context_window.json --- model_prices_and_context_window.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/model_prices_and_context_window.json b/model_prices_and_context_window.json index 111b9f8c3..d56450b23 100644 --- a/model_prices_and_context_window.json +++ b/model_prices_and_context_window.json @@ -108,7 +108,7 @@ }, "gpt-3.5-turbo": { "max_tokens": 4097, - "max_input_tokens": 4097, + "max_input_tokens": 16385, "max_output_tokens": 4096, "input_cost_per_token": 0.0000015, "output_cost_per_token": 0.000002, @@ -2259,4 +2259,4 @@ "mode": "embedding" } -} \ No newline at end of file +} From da4b150398f9e7790ed9c33e831441f1ddcf32a0 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 16:49:39 -0800 Subject: [PATCH 07/74] (feat) init cloud form stack --- deploy/just_ec2.yaml | 8 ++++++++ 1 file changed, 8 insertions(+) create mode 100644 deploy/just_ec2.yaml diff --git a/deploy/just_ec2.yaml b/deploy/just_ec2.yaml new file mode 100644 index 000000000..5c51233dd --- /dev/null +++ b/deploy/just_ec2.yaml @@ -0,0 +1,8 @@ +--- +Resources: + MyEC2Instance: + Type: "AWS::EC2::Instance" + Properties: + AvailabilityZone: "us-east-1a" + ImageId: "ami-0f403e3180720dd7e" # Replace with your desired AMI ID + InstanceType: "t2.micro" From 702e46b53d4f7a130eab4d0e6480291037896290 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 17:50:14 -0800 Subject: [PATCH 08/74] (build) stack with db --- deploy/just_ec2.yaml | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/deploy/just_ec2.yaml b/deploy/just_ec2.yaml index 5c51233dd..3097b6be0 100644 --- a/deploy/just_ec2.yaml +++ b/deploy/just_ec2.yaml @@ -1,8 +1,17 @@ --- Resources: - MyEC2Instance: + LiteLLMServer: Type: "AWS::EC2::Instance" Properties: AvailabilityZone: "us-east-1a" ImageId: "ami-0f403e3180720dd7e" # Replace with your desired AMI ID InstanceType: "t2.micro" + LiteLLMDB: + Type: "AWS::RDS::DBInstance" + Properties: + AllocatedStorage: 5 + Engine: "postgres" + MasterUsername: "litellmAdmin" # Replace with your desired master username + MasterUserPassword: "litellmPassword" # Replace with your desired secure password + DBInstanceClass: "db.t3.micro" + AvailabilityZone: "us-east-1a" From 2f960a965123b7bb73bffd5a86c3c9c3a36a2847 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 17:51:12 -0800 Subject: [PATCH 09/74] (feat) auto-scale --- deploy/just_ec2.yaml | 49 ++++++++++++++++++++++++++++++++++---------- 1 file changed, 38 insertions(+), 11 deletions(-) diff --git a/deploy/just_ec2.yaml b/deploy/just_ec2.yaml index 3097b6be0..97060b6c3 100644 --- a/deploy/just_ec2.yaml +++ b/deploy/just_ec2.yaml @@ -1,17 +1,44 @@ ---- Resources: LiteLLMServer: - Type: "AWS::EC2::Instance" + Type: AWS::EC2::Instance Properties: - AvailabilityZone: "us-east-1a" - ImageId: "ami-0f403e3180720dd7e" # Replace with your desired AMI ID - InstanceType: "t2.micro" + AvailabilityZone: us-east-1a + ImageId: ami-0f403e3180720dd7e + InstanceType: t2.micro + + LiteLLMServerAutoScalingGroup: + Type: AWS::AutoScaling::AutoScalingGroup + Properties: + AvailabilityZones: + - us-east-1a + LaunchConfigurationName: !Ref LiteLLMServerLaunchConfig + MinSize: 1 + MaxSize: 3 + DesiredCapacity: 1 + HealthCheckGracePeriod: 300 + + LiteLLMServerLaunchConfig: + Type: AWS::AutoScaling::LaunchConfiguration + Properties: + ImageId: ami-0f403e3180720dd7e # Replace with your desired AMI ID + InstanceType: t2.micro + + LiteLLMServerScalingPolicy: + Type: AWS::AutoScaling::ScalingPolicy + Properties: + AutoScalingGroupName: !Ref LiteLLMServerAutoScalingGroup + PolicyType: TargetTrackingScaling + TargetTrackingConfiguration: + PredefinedMetricSpecification: + PredefinedMetricType: ASGCPUUtilization + TargetValue: 60.0 + LiteLLMDB: - Type: "AWS::RDS::DBInstance" + Type: AWS::RDS::DBInstance Properties: AllocatedStorage: 5 - Engine: "postgres" - MasterUsername: "litellmAdmin" # Replace with your desired master username - MasterUserPassword: "litellmPassword" # Replace with your desired secure password - DBInstanceClass: "db.t3.micro" - AvailabilityZone: "us-east-1a" + Engine: postgres + MasterUsername: litellmAdmin + MasterUserPassword: litellmPassword + DBInstanceClass: db.t3.micro + AvailabilityZone: us-east-1a \ No newline at end of file From 323f15aa2f6146f80e826019c431cf687e13091b Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 18:06:59 -0800 Subject: [PATCH 10/74] (fix) litellm cloud formation stack --- .../cloudformation_stack/litellm.yaml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) rename deploy/just_ec2.yaml => enterprise/cloudformation_stack/litellm.yaml (93%) diff --git a/deploy/just_ec2.yaml b/enterprise/cloudformation_stack/litellm.yaml similarity index 93% rename from deploy/just_ec2.yaml rename to enterprise/cloudformation_stack/litellm.yaml index 97060b6c3..c30956b94 100644 --- a/deploy/just_ec2.yaml +++ b/enterprise/cloudformation_stack/litellm.yaml @@ -30,13 +30,13 @@ Resources: PolicyType: TargetTrackingScaling TargetTrackingConfiguration: PredefinedMetricSpecification: - PredefinedMetricType: ASGCPUUtilization + PredefinedMetricType: ASGAverageCPUUtilization TargetValue: 60.0 LiteLLMDB: Type: AWS::RDS::DBInstance Properties: - AllocatedStorage: 5 + AllocatedStorage: 20 Engine: postgres MasterUsername: litellmAdmin MasterUserPassword: litellmPassword From 6f0faca85b1a2be0cb36ad5dcc072ed1a4fbaefb Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 18:33:09 -0800 Subject: [PATCH 11/74] (feat) print debug info per deployment --- litellm/proxy/proxy_config.yaml | 59 ++------------------- litellm/proxy/tests/load_test_completion.py | 6 +-- litellm/router.py | 45 ++++++++++++++++ 3 files changed, 51 insertions(+), 59 deletions(-) diff --git a/litellm/proxy/proxy_config.yaml b/litellm/proxy/proxy_config.yaml index 6b4b7a8f6..654a50b2f 100644 --- a/litellm/proxy/proxy_config.yaml +++ b/litellm/proxy/proxy_config.yaml @@ -5,63 +5,12 @@ model_list: api_base: os.environ/AZURE_API_BASE api_key: os.environ/AZURE_API_KEY api_version: "2023-07-01-preview" - model_info: - mode: chat - max_tokens: 4096 - base_model: azure/gpt-4-1106-preview - access_groups: ["public"] - - model_name: openai-gpt-3.5 + - model_name: azure-gpt-3.5 litellm_params: model: gpt-3.5-turbo api_key: os.environ/OPENAI_API_KEY model_info: access_groups: ["public"] - - model_name: anthropic-claude-v2.1 - litellm_params: - model: bedrock/anthropic.claude-v2:1 - timeout: 300 # sets a 5 minute timeout - model_info: - access_groups: ["private"] - - model_name: anthropic-claude-v2 - litellm_params: - model: bedrock/anthropic.claude-v2 - - model_name: bedrock-cohere - litellm_params: - model: bedrock/cohere.command-text-v14 - timeout: 0.0001 - - model_name: gpt-4 - litellm_params: - model: azure/chatgpt-v-2 - api_base: https://openai-gpt-4-test-v-1.openai.azure.com/ - api_version: "2023-05-15" - api_key: os.environ/AZURE_API_KEY # The `os.environ/` prefix tells litellm to read this from the env. See https://docs.litellm.ai/docs/simple_proxy#load-api-keys-from-vault - model_info: - base_model: azure/gpt-4 - - model_name: text-moderation-stable - litellm_params: - model: text-moderation-stable - api_key: os.environ/OPENAI_API_KEY -litellm_settings: - fallbacks: [{"openai-gpt-3.5": ["azure-gpt-3.5"]}] - success_callback: ['langfuse'] - # setting callback class - callbacks: custom_callbacks.proxy_handler_instance # sets litellm.callbacks = [proxy_handler_instance] - -general_settings: - master_key: sk-1234 - alerting: ["slack"] - alerting_threshold: 10 # sends alerts if requests hang for 2 seconds - # database_type: "dynamo_db" - # database_args: { # 👈 all args - https://github.com/BerriAI/litellm/blob/befbcbb7ac8f59835ce47415c128decf37aac328/litellm/proxy/_types.py#L190 - # "billing_mode": "PAY_PER_REQUEST", - # "region_name": "us-west-2", - # "ssl_verify": False - # } - - - - - -environment_variables: - # otel: True # OpenTelemetry Logger - # master_key: sk-1234 # [OPTIONAL] Only use this if you to require all calls to contain this key (Authorization: Bearer sk-1234) +router_settings: + set_verbose: True + debug_level: "DEBUG" \ No newline at end of file diff --git a/litellm/proxy/tests/load_test_completion.py b/litellm/proxy/tests/load_test_completion.py index d708f3036..c6e5f480e 100644 --- a/litellm/proxy/tests/load_test_completion.py +++ b/litellm/proxy/tests/load_test_completion.py @@ -4,9 +4,7 @@ import uuid import traceback -litellm_client = AsyncOpenAI( - base_url="http://0.0.0.0:4000", api_key="sk-iNwH_oOtAQ6syi_2gkEOpQ" -) +litellm_client = AsyncOpenAI(base_url="http://0.0.0.0:4000", api_key="sk-1234") async def litellm_completion(): @@ -29,7 +27,7 @@ async def litellm_completion(): async def main(): for i in range(150): start = time.time() - n = 2000 # Number of concurrent tasks + n = 20 # Number of concurrent tasks tasks = [litellm_completion() for _ in range(n)] chat_completions = await asyncio.gather(*tasks) diff --git a/litellm/router.py b/litellm/router.py index 6f33d0b0d..5c90ce834 100644 --- a/litellm/router.py +++ b/litellm/router.py @@ -240,6 +240,21 @@ class Router: {"caching_groups": caching_groups} ) + self.deployment_stats: dict = {} # used for debugging load balancing + """ + deployment_stats = { + "122999-2828282-277: + { + "model": "gpt-3", + "api_base": "http://localhost:8000", + "num_requests": 20, + "avg_latency": 0.001, + "num_failures": 0, + "num_successes": 20 + } + } + """ + ### ROUTING SETUP ### if routing_strategy == "least-busy": self.leastbusy_logger = LeastBusyLoggingHandler( @@ -390,6 +405,10 @@ class Router: messages=messages, specific_deployment=kwargs.pop("specific_deployment", None), ) + if self.set_verbose == True and self.debug_level == "DEBUG": + # debug how often this deployment picked + self._print_deployment_metrics(deployment=deployment) + kwargs.setdefault("metadata", {}).update( { "deployment": deployment["litellm_params"]["model"], @@ -2124,6 +2143,32 @@ class Router: ) return deployment + def _print_deployment_metrics(self, deployment): + litellm_params = deployment["litellm_params"] + api_base = litellm_params.get("api_base", "") + model = litellm_params.get("model", "") + + model_id = deployment.get("model_info", {}).get("id", None) + + # update self.deployment_stats + if model_id is not None: + if model_id in self.deployment_stats: + # only update num_requests + self.deployment_stats[model_id]["num_requests"] += 1 + else: + self.deployment_stats[model_id] = { + "api_base": api_base, + "model": model, + "num_requests": 1, + } + from pprint import pformat + + # Assuming self.deployment_stats is your dictionary + formatted_stats = pformat(self.deployment_stats) + + # Assuming verbose_router_logger is your logger + verbose_router_logger.info("self.deployment_stats: \n%s", formatted_stats) + def flush_cache(self): litellm.cache = None self.cache.flush_cache() From 86ac020b125555d252c0c0169b12429db636ba8b Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 18:50:45 -0800 Subject: [PATCH 12/74] (fix) show latency per deployment on router debug logs --- litellm/router.py | 74 ++++++++++++++++++++++++++++++++++------------- 1 file changed, 54 insertions(+), 20 deletions(-) diff --git a/litellm/router.py b/litellm/router.py index 5c90ce834..d4c0be862 100644 --- a/litellm/router.py +++ b/litellm/router.py @@ -465,6 +465,9 @@ class Router: verbose_router_logger.info( f"litellm.acompletion(model={model_name})\033[32m 200 OK\033[0m" ) + if self.set_verbose == True and self.debug_level == "DEBUG": + # debug how often this deployment picked + self._print_deployment_metrics(deployment=deployment, response=response) return response except Exception as e: verbose_router_logger.info( @@ -2143,31 +2146,62 @@ class Router: ) return deployment - def _print_deployment_metrics(self, deployment): - litellm_params = deployment["litellm_params"] - api_base = litellm_params.get("api_base", "") - model = litellm_params.get("model", "") + def _print_deployment_metrics(self, deployment, response=None): + try: + litellm_params = deployment["litellm_params"] + api_base = litellm_params.get("api_base", "") + model = litellm_params.get("model", "") - model_id = deployment.get("model_info", {}).get("id", None) + model_id = deployment.get("model_info", {}).get("id", None) + if response is None: - # update self.deployment_stats - if model_id is not None: - if model_id in self.deployment_stats: - # only update num_requests - self.deployment_stats[model_id]["num_requests"] += 1 + # update self.deployment_stats + if model_id is not None: + if model_id in self.deployment_stats: + # only update num_requests + self.deployment_stats[model_id]["num_requests"] += 1 + else: + self.deployment_stats[model_id] = { + "api_base": api_base, + "model": model, + "num_requests": 1, + } else: - self.deployment_stats[model_id] = { - "api_base": api_base, - "model": model, - "num_requests": 1, - } - from pprint import pformat + # check response_ms and update num_successes + response_ms = response.get("_response_ms", 0) + if model_id is not None: + if model_id in self.deployment_stats: + # check if avg_latency exists + if "avg_latency" in self.deployment_stats[model_id]: + # update avg_latency + self.deployment_stats[model_id]["avg_latency"] = ( + self.deployment_stats[model_id]["avg_latency"] + + response_ms + ) / self.deployment_stats[model_id]["num_successes"] + else: + self.deployment_stats[model_id]["avg_latency"] = response_ms - # Assuming self.deployment_stats is your dictionary - formatted_stats = pformat(self.deployment_stats) + # check if num_successes exists + if "num_successes" in self.deployment_stats[model_id]: + self.deployment_stats[model_id]["num_successes"] += 1 + else: + self.deployment_stats[model_id]["num_successes"] = 1 + else: + self.deployment_stats[model_id] = { + "api_base": api_base, + "model": model, + "num_successes": 1, + "avg_latency": response_ms, + } + from pprint import pformat - # Assuming verbose_router_logger is your logger - verbose_router_logger.info("self.deployment_stats: \n%s", formatted_stats) + # Assuming self.deployment_stats is your dictionary + formatted_stats = pformat(self.deployment_stats) + + # Assuming verbose_router_logger is your logger + verbose_router_logger.info("self.deployment_stats: \n%s", formatted_stats) + except Exception as e: + verbose_router_logger.error(f"Error in _print_deployment_metrics: {str(e)}") def flush_cache(self): litellm.cache = None From 4a4d36d923dfeecc2cfed8e88a304dbdc7f18cdc Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 20:45:32 -0800 Subject: [PATCH 13/74] (feat) bump litellm --- litellm/model_prices_and_context_window_backup.json | 4 ++-- pyproject.toml | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/litellm/model_prices_and_context_window_backup.json b/litellm/model_prices_and_context_window_backup.json index 111b9f8c3..d56450b23 100644 --- a/litellm/model_prices_and_context_window_backup.json +++ b/litellm/model_prices_and_context_window_backup.json @@ -108,7 +108,7 @@ }, "gpt-3.5-turbo": { "max_tokens": 4097, - "max_input_tokens": 4097, + "max_input_tokens": 16385, "max_output_tokens": 4096, "input_cost_per_token": 0.0000015, "output_cost_per_token": 0.000002, @@ -2259,4 +2259,4 @@ "mode": "embedding" } -} \ No newline at end of file +} diff --git a/pyproject.toml b/pyproject.toml index 5880791ac..81daa25ed 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "litellm" -version = "1.30.1" +version = "1.30.2" description = "Library to easily interface with LLM API providers" authors = ["BerriAI"] license = "MIT" @@ -74,7 +74,7 @@ requires = ["poetry-core", "wheel"] build-backend = "poetry.core.masonry.api" [tool.commitizen] -version = "1.30.1" +version = "1.30.2" version_files = [ "pyproject.toml:^version" ] From b4e12fb8fd6f5fd60563b9f228257dc5315fbff7 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Thu, 7 Mar 2024 21:01:28 -0800 Subject: [PATCH 14/74] (docs) litellm cloud formation stack --- docs/my-website/docs/proxy/deploy.md | 43 +++++++++++++++++++++++++++- 1 file changed, 42 insertions(+), 1 deletion(-) diff --git a/docs/my-website/docs/proxy/deploy.md b/docs/my-website/docs/proxy/deploy.md index 8ffc2adf5..6de8625d0 100644 --- a/docs/my-website/docs/proxy/deploy.md +++ b/docs/my-website/docs/proxy/deploy.md @@ -218,8 +218,49 @@ Provide an ssl certificate when starting litellm proxy server ## Platform-specific Guide - + + + +### AWS Cloud Formation Stack +LiteLLM AWS Cloudformation Stack - **Get the best LiteLLM AutoScaling Policy and Provision the DB for LiteLLM Proxy** + +This will provision: +- LiteLLMServer - EC2 Instance +- LiteLLMServerAutoScalingGroup +- LiteLLMServerScalingPolicy (autoscaling policy) +- LiteLLMDB - RDS::DBInstance + +#### Using AWS Cloud Formation Stack +**LiteLLM Cloudformation stack is located [here - litellm.yaml](https://github.com/BerriAI/litellm/blob/main/enterprise/cloudformation_stack/litellm.yaml)** + +#### 1. Create the CloudFormation Stack: +In the AWS Management Console, navigate to the CloudFormation service, and click on "Create Stack." + +On the "Create Stack" page, select "Upload a template file" and choose the litellm.yaml file + +Now monitor the stack was created successfully. + +#### 2. Get the Database URL: +Once the stack is created, get the DatabaseURL of the Database resource, copy this value + +#### 3. Connect to the EC2 Instance and deploy litellm on the EC2 container +From the EC2 console, connect to the instance created by the stack (e.g., using SSH). + +Run the following command, replacing with the value you copied in step 2 + +```shell +docker run --name litellm-proxy \ + -e DATABASE_URL= \ + -p 4000:4000 \ + ghcr.io/berriai/litellm-database:main-latest +``` + +#### 4. Access the Application: + +Once the container is running, you can access the application by going to `http://:4000` in your browser. + + ### Deploy on Google Cloud Run From 0e7b30bec9ba765d92344a2078eec369e77def6c Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 08:01:10 -0800 Subject: [PATCH 15/74] fix(utils.py): return function name for ollama_chat function calls --- docs/my-website/docs/providers/ollama.md | 6 +++ litellm/__init__.py | 1 + litellm/llms/ollama_chat.py | 68 ++++++++++++++++++++++-- litellm/utils.py | 30 +++-------- 4 files changed, 79 insertions(+), 26 deletions(-) diff --git a/docs/my-website/docs/providers/ollama.md b/docs/my-website/docs/providers/ollama.md index 51d91ccb6..78c91bb63 100644 --- a/docs/my-website/docs/providers/ollama.md +++ b/docs/my-website/docs/providers/ollama.md @@ -5,6 +5,12 @@ LiteLLM supports all models from [Ollama](https://github.com/jmorganca/ollama) Open In Colab +:::info + +We recommend using [ollama_chat](#using-ollama-apichat) for better responses. + +::: + ## Pre-requisites Ensure you have your ollama server running diff --git a/litellm/__init__.py b/litellm/__init__.py index 017bd46ac..506147166 100644 --- a/litellm/__init__.py +++ b/litellm/__init__.py @@ -588,6 +588,7 @@ from .llms.petals import PetalsConfig from .llms.vertex_ai import VertexAIConfig from .llms.sagemaker import SagemakerConfig from .llms.ollama import OllamaConfig +from .llms.ollama_chat import OllamaChatConfig from .llms.maritalk import MaritTalkConfig from .llms.bedrock import ( AmazonTitanConfig, diff --git a/litellm/llms/ollama_chat.py b/litellm/llms/ollama_chat.py index dec74fa92..8378a95ff 100644 --- a/litellm/llms/ollama_chat.py +++ b/litellm/llms/ollama_chat.py @@ -18,7 +18,7 @@ class OllamaError(Exception): ) # Call the base class constructor with the parameters it needs -class OllamaConfig: +class OllamaChatConfig: """ Reference: https://github.com/jmorganca/ollama/blob/main/docs/api.md#parameters @@ -108,6 +108,7 @@ class OllamaConfig: k: v for k, v in cls.__dict__.items() if not k.startswith("__") + and k != "function_name" # special param for function calling and not isinstance( v, ( @@ -120,6 +121,61 @@ class OllamaConfig: and v is not None } + def get_supported_openai_params( + self, + ): + return [ + "max_tokens", + "stream", + "top_p", + "temperature", + "frequency_penalty", + "stop", + "tools", + "tool_choice", + "functions", + ] + + def map_openai_params(self, non_default_params: dict, optional_params: dict): + for param, value in non_default_params.items(): + if param == "max_tokens": + optional_params["num_predict"] = value + if param == "stream": + optional_params["stream"] = value + if param == "temperature": + optional_params["temperature"] = value + if param == "top_p": + optional_params["top_p"] = value + if param == "frequency_penalty": + optional_params["repeat_penalty"] = param + if param == "stop": + optional_params["stop"] = value + ### FUNCTION CALLING LOGIC ### + if param == "tools": + # ollama actually supports json output + optional_params["format"] = "json" + litellm.add_function_to_prompt = ( + True # so that main.py adds the function call to the prompt + ) + optional_params["functions_unsupported_model"] = value + + if len(optional_params["functions_unsupported_model"]) == 1: + optional_params["function_name"] = optional_params[ + "functions_unsupported_model" + ][0]["function"]["name"] + + if param == "functions": + # ollama actually supports json output + optional_params["format"] = "json" + litellm.add_function_to_prompt = ( + True # so that main.py adds the function call to the prompt + ) + optional_params["functions_unsupported_model"] = non_default_params.pop( + "functions" + ) + non_default_params.pop("tool_choice", None) # causes ollama requests to hang + return optional_params + # ollama implementation def get_ollama_response( @@ -138,7 +194,7 @@ def get_ollama_response( url = f"{api_base}/api/chat" ## Load Config - config = litellm.OllamaConfig.get_config() + config = litellm.OllamaChatConfig.get_config() for k, v in config.items(): if ( k not in optional_params @@ -147,6 +203,7 @@ def get_ollama_response( stream = optional_params.pop("stream", False) format = optional_params.pop("format", None) + function_name = optional_params.pop("function_name", None) for m in messages: if "role" in m and m["role"] == "tool": @@ -187,6 +244,7 @@ def get_ollama_response( model_response=model_response, encoding=encoding, logging_obj=logging_obj, + function_name=function_name, ) return response elif stream == True: @@ -290,7 +348,9 @@ async def ollama_async_streaming(url, data, model_response, encoding, logging_ob traceback.print_exc() -async def ollama_acompletion(url, data, model_response, encoding, logging_obj): +async def ollama_acompletion( + url, data, model_response, encoding, logging_obj, function_name +): data["stream"] = False try: timeout = aiohttp.ClientTimeout(total=litellm.request_timeout) # 10 minutes @@ -324,7 +384,7 @@ async def ollama_acompletion(url, data, model_response, encoding, logging_obj): "id": f"call_{str(uuid.uuid4())}", "function": { "arguments": response_json["message"]["content"], - "name": "", + "name": function_name or "", }, "type": "function", } diff --git a/litellm/utils.py b/litellm/utils.py index 4c48c5516..38836a4bc 100644 --- a/litellm/utils.py +++ b/litellm/utils.py @@ -4147,8 +4147,9 @@ def get_optional_params( and custom_llm_provider != "mistral" and custom_llm_provider != "anthropic" and custom_llm_provider != "bedrock" + and custom_llm_provider != "ollama_chat" ): - if custom_llm_provider == "ollama" or custom_llm_provider == "ollama_chat": + if custom_llm_provider == "ollama": # ollama actually supports json output optional_params["format"] = "json" litellm.add_function_to_prompt = ( @@ -4174,7 +4175,7 @@ def get_optional_params( else: raise UnsupportedParamsError( status_code=500, - message=f"Function calling is not supported by {custom_llm_provider}. To add it to the prompt, set `litellm.add_function_to_prompt = True`.", + message=f"Function calling is not supported by {custom_llm_provider}.", ) def _check_valid_arg(supported_params): @@ -4687,28 +4688,13 @@ def get_optional_params( if stop is not None: optional_params["stop"] = stop elif custom_llm_provider == "ollama_chat": - supported_params = [ - "max_tokens", - "stream", - "top_p", - "temperature", - "frequency_penalty", - "stop", - ] + supported_params = litellm.OllamaChatConfig().get_supported_openai_params() + _check_valid_arg(supported_params=supported_params) - if max_tokens is not None: - optional_params["num_predict"] = max_tokens - if stream: - optional_params["stream"] = stream - if temperature is not None: - optional_params["temperature"] = temperature - if top_p is not None: - optional_params["top_p"] = top_p - if frequency_penalty is not None: - optional_params["repeat_penalty"] = frequency_penalty - if stop is not None: - optional_params["stop"] = stop + optional_params = litellm.OllamaChatConfig().map_openai_params( + non_default_params=non_default_params, optional_params=optional_params + ) elif custom_llm_provider == "nlp_cloud": supported_params = [ "max_tokens", From 2f9a39f30c3561fa40340796f9982ee6afc82986 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 08:12:22 -0800 Subject: [PATCH 16/74] refactor(main.py): trigger new build --- litellm/main.py | 1 - 1 file changed, 1 deletion(-) diff --git a/litellm/main.py b/litellm/main.py index dfe6c5f31..63649844a 100644 --- a/litellm/main.py +++ b/litellm/main.py @@ -10,7 +10,6 @@ import os, openai, sys, json, inspect, uuid, datetime, threading from typing import Any, Literal, Union from functools import partial - import dotenv, traceback, random, asyncio, time, contextvars from copy import deepcopy import httpx From f8f01e52241684a64334924f4f20b1ed34600378 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 08:12:36 -0800 Subject: [PATCH 17/74] =?UTF-8?q?bump:=20version=201.30.2=20=E2=86=92=201.?= =?UTF-8?q?30.3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- pyproject.toml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 81daa25ed..80f5c822c 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "litellm" -version = "1.30.2" +version = "1.30.3" description = "Library to easily interface with LLM API providers" authors = ["BerriAI"] license = "MIT" @@ -74,7 +74,7 @@ requires = ["poetry-core", "wheel"] build-backend = "poetry.core.masonry.api" [tool.commitizen] -version = "1.30.2" +version = "1.30.3" version_files = [ "pyproject.toml:^version" ] From f70feb180699aef63d2d99e3207d7fb8f2bae728 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 09:33:54 -0800 Subject: [PATCH 18/74] (test) name with claude-3 --- litellm/tests/test_completion.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/litellm/tests/test_completion.py b/litellm/tests/test_completion.py index 4db664dde..e54617bd9 100644 --- a/litellm/tests/test_completion.py +++ b/litellm/tests/test_completion.py @@ -83,12 +83,13 @@ def test_completion_claude(): def test_completion_claude_3_empty_response(): + litellm.set_verbose = True messages = [ { "role": "system", "content": "You are 2twNLGfqk4GMOn3ffp4p.", }, - {"role": "user", "content": "Hi gm!"}, + {"role": "user", "content": "Hi gm!", "name": "ishaan"}, {"role": "assistant", "content": "Good morning! How are you doing today?"}, { "role": "user", From 96e369613882a7e6429fc29709f3649a2ff5bca8 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 09:41:58 -0800 Subject: [PATCH 19/74] (fix) support name on perplexity/ --- litellm/llms/openai.py | 24 ++++++++++++++++-------- litellm/llms/prompt_templates/factory.py | 13 +++++++++++-- 2 files changed, 27 insertions(+), 10 deletions(-) diff --git a/litellm/llms/openai.py b/litellm/llms/openai.py index 90846b627..de605edff 100644 --- a/litellm/llms/openai.py +++ b/litellm/llms/openai.py @@ -237,14 +237,22 @@ class OpenAIChatCompletion(BaseLLM): status_code=422, message=f"Timeout needs to be a float" ) - if custom_llm_provider == "mistral": - # check if message content passed in as list, and not string - messages = prompt_factory( - model=model, - messages=messages, - custom_llm_provider=custom_llm_provider, - ) - + if custom_llm_provider != "openai": + # process all OpenAI compatible provider logic here + if custom_llm_provider == "mistral": + # check if message content passed in as list, and not string + messages = prompt_factory( + model=model, + messages=messages, + custom_llm_provider=custom_llm_provider, + ) + if custom_llm_provider == "perplexity" and messages is not None: + # check if messages.name is passed + supported, if not supported remove + messages = prompt_factory( + model=model, + messages=messages, + custom_llm_provider=custom_llm_provider, + ) for _ in range( 2 ): # if call fails due to alternating messages, retry with reformatted message diff --git a/litellm/llms/prompt_templates/factory.py b/litellm/llms/prompt_templates/factory.py index 616833a2e..a13130c62 100644 --- a/litellm/llms/prompt_templates/factory.py +++ b/litellm/llms/prompt_templates/factory.py @@ -556,6 +556,7 @@ def anthropic_messages_pt(messages: list): 3. Each message must alternate between "user" and "assistant" (this is not addressed as now by litellm) 4. final assistant content cannot end with trailing whitespace (anthropic raises an error otherwise) 5. System messages are a separate param to the Messages API (used for tool calling) + 6. Ensure we only accept role, content. (message.name is not supported) """ ## Ensure final assistant message has no trailing whitespace last_assistant_message_idx: Optional[int] = None @@ -583,7 +584,9 @@ def anthropic_messages_pt(messages: list): new_content.append({"type": "text", "text": m["text"]}) new_messages.append({"role": messages[0]["role"], "content": new_content}) # type: ignore else: - new_messages.append(messages[0]) + new_messages.append( + {"role": messages[0]["role"], "content": messages[0]["content"]} + ) return new_messages @@ -606,7 +609,9 @@ def anthropic_messages_pt(messages: list): new_content.append({"type": "text", "content": m["text"]}) new_messages.append({"role": messages[i]["role"], "content": new_content}) # type: ignore else: - new_messages.append(messages[i]) + new_messages.append( + {"role": messages[i]["role"], "content": messages[i]["content"]} + ) if messages[i]["role"] == messages[i + 1]["role"]: if messages[i]["role"] == "user": @@ -897,6 +902,10 @@ def prompt_factory( return anthropic_pt(messages=messages) elif "mistral." in model: return mistral_instruct_pt(messages=messages) + elif custom_llm_provider == "perplexity": + for message in messages: + message.pop("name", None) + return messages try: if "meta-llama/llama-2" in model and "chat" in model: return llama_2_chat_pt(messages=messages) From 696eb54455c8c9caba86ac14e72f365b2c853223 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 10:25:19 -0800 Subject: [PATCH 20/74] feat(main.py): support openai transcription endpoints enable user to load balance between openai + azure transcription endpoints --- litellm/llms/openai.py | 100 +++++++++++++++++- litellm/main.py | 72 ++++++++++++- ...odel_prices_and_context_window_backup.json | 12 +++ litellm/utils.py | 60 ++++++++++- model_prices_and_context_window.json | 12 +++ tests/gettysburg.wav | Bin 0 -> 775192 bytes tests/test_whisper.py | 26 +++++ 7 files changed, 275 insertions(+), 7 deletions(-) create mode 100644 tests/gettysburg.wav create mode 100644 tests/test_whisper.py diff --git a/litellm/llms/openai.py b/litellm/llms/openai.py index 90846b627..fca950d31 100644 --- a/litellm/llms/openai.py +++ b/litellm/llms/openai.py @@ -1,4 +1,4 @@ -from typing import Optional, Union, Any +from typing import Optional, Union, Any, BinaryIO import types, time, json, traceback import httpx from .base import BaseLLM @@ -9,6 +9,7 @@ from litellm.utils import ( CustomStreamWrapper, convert_to_model_response_object, Usage, + TranscriptionResponse, ) from typing import Callable, Optional import aiohttp, requests @@ -766,6 +767,103 @@ class OpenAIChatCompletion(BaseLLM): else: raise OpenAIError(status_code=500, message=str(e)) + def audio_transcriptions( + self, + model: str, + audio_file: BinaryIO, + optional_params: dict, + model_response: TranscriptionResponse, + timeout: float, + api_key: Optional[str] = None, + api_base: Optional[str] = None, + client=None, + max_retries=None, + logging_obj=None, + atranscriptions: bool = False, + ): + data = {"model": model, "file": audio_file, **optional_params} + if atranscriptions == True: + return self.async_audio_transcriptions( + audio_file=audio_file, + data=data, + model_response=model_response, + timeout=timeout, + api_key=api_key, + api_base=api_base, + client=client, + max_retries=max_retries, + logging_obj=logging_obj, + ) + if client is None: + openai_client = OpenAI( + api_key=api_key, + base_url=api_base, + http_client=litellm.client_session, + timeout=timeout, + max_retries=max_retries, + ) + else: + openai_client = client + response = openai_client.audio.transcriptions.create( + **data, timeout=timeout # type: ignore + ) + + stringified_response = response.model_dump() + ## LOGGING + logging_obj.post_call( + input=audio_file.name, + api_key=api_key, + additional_args={"complete_input_dict": data}, + original_response=stringified_response, + ) + final_response = convert_to_model_response_object(response_object=stringified_response, model_response_object=model_response, response_type="audio_transcription") # type: ignore + return final_response + + async def async_audio_transcriptions( + self, + audio_file: BinaryIO, + data: dict, + model_response: TranscriptionResponse, + timeout: float, + api_key: Optional[str] = None, + api_base: Optional[str] = None, + client=None, + max_retries=None, + logging_obj=None, + ): + response = None + try: + if client is None: + openai_aclient = AsyncOpenAI( + api_key=api_key, + base_url=api_base, + http_client=litellm.aclient_session, + timeout=timeout, + max_retries=max_retries, + ) + else: + openai_aclient = client + response = await openai_aclient.audio.transcriptions.create( + **data, timeout=timeout + ) # type: ignore + stringified_response = response.model_dump() + ## LOGGING + logging_obj.post_call( + input=audio_file.name, + api_key=api_key, + additional_args={"complete_input_dict": data}, + original_response=stringified_response, + ) + return convert_to_model_response_object(response_object=stringified_response, model_response_object=model_response, response_type="image_generation") # type: ignore + except Exception as e: + ## LOGGING + logging_obj.post_call( + input=input, + api_key=api_key, + original_response=str(e), + ) + raise e + async def ahealth_check( self, model: Optional[str], diff --git a/litellm/main.py b/litellm/main.py index 63649844a..2df9686fe 100644 --- a/litellm/main.py +++ b/litellm/main.py @@ -8,7 +8,7 @@ # Thank you ! We ❤️ you! - Krrish & Ishaan import os, openai, sys, json, inspect, uuid, datetime, threading -from typing import Any, Literal, Union +from typing import Any, Literal, Union, BinaryIO from functools import partial import dotenv, traceback, random, asyncio, time, contextvars from copy import deepcopy @@ -3043,7 +3043,6 @@ def moderation( return response -##### Moderation ####################### @client async def amoderation(input: str, model: str, api_key: Optional[str] = None, **kwargs): # only supports open ai for now @@ -3310,6 +3309,75 @@ def image_generation( ) +##### Transcription ####################### + + +async def atranscription(*args, **kwargs): + """ + Calls openai + azure whisper endpoints. + + Allows router to load balance between them + """ + pass + + +@client +def transcription( + model: str, + file: BinaryIO, + ## OPTIONAL OPENAI PARAMS ## + language: Optional[str] = None, + prompt: Optional[str] = None, + response_format: Optional[ + Literal["json", "text", "srt", "verbose_json", "vtt"] + ] = None, + temperature: Optional[int] = None, # openai defaults this to 0 + ## LITELLM PARAMS ## + user: Optional[str] = None, + timeout=600, # default to 10 minutes + api_key: Optional[str] = None, + api_base: Optional[str] = None, + api_version: Optional[str] = None, + litellm_logging_obj=None, + custom_llm_provider=None, + **kwargs, +): + """ + Calls openai + azure whisper endpoints. + + Allows router to load balance between them + """ + atranscriptions = kwargs.get("atranscriptions", False) + litellm_call_id = kwargs.get("litellm_call_id", None) + logger_fn = kwargs.get("logger_fn", None) + proxy_server_request = kwargs.get("proxy_server_request", None) + model_info = kwargs.get("model_info", None) + metadata = kwargs.get("metadata", {}) + + model_response = litellm.utils.TranscriptionResponse() + + # model, custom_llm_provider, dynamic_api_key, api_base = get_llm_provider(model=model, custom_llm_provider=custom_llm_provider, api_base=api_base) # type: ignore + custom_llm_provider = "openai" + + optional_params = { + "language": language, + "prompt": prompt, + "response_format": response_format, + "temperature": None, # openai defaults this to 0 + } + if custom_llm_provider == "openai": + return openai_chat_completions.audio_transcriptions( + model=model, + audio_file=file, + optional_params=optional_params, + model_response=model_response, + atranscriptions=atranscriptions, + timeout=timeout, + logging_obj=litellm_logging_obj, + ) + return + + ##### Health Endpoints ####################### diff --git a/litellm/model_prices_and_context_window_backup.json b/litellm/model_prices_and_context_window_backup.json index d56450b23..18c4b0d9a 100644 --- a/litellm/model_prices_and_context_window_backup.json +++ b/litellm/model_prices_and_context_window_backup.json @@ -293,6 +293,18 @@ "output_cost_per_pixel": 0.0, "litellm_provider": "openai" }, + "whisper-1": { + "mode": "audio_transcription", + "input_cost_per_second": 0, + "output_cost_per_second": 0.0001, + "litellm_provider": "openai" + }, + "azure/whisper-1": { + "mode": "audio_transcription", + "input_cost_per_second": 0, + "output_cost_per_second": 0.0001, + "litellm_provider": "azure" + }, "azure/gpt-4-0125-preview": { "max_tokens": 128000, "max_input_tokens": 128000, diff --git a/litellm/utils.py b/litellm/utils.py index 38836a4bc..330903f5a 100644 --- a/litellm/utils.py +++ b/litellm/utils.py @@ -10,7 +10,6 @@ import sys, re, binascii, struct import litellm import dotenv, json, traceback, threading, base64, ast - import subprocess, os from os.path import abspath, join, dirname import litellm, openai @@ -98,7 +97,7 @@ try: except Exception as e: verbose_logger.debug(f"Exception import enterprise features {str(e)}") -from typing import cast, List, Dict, Union, Optional, Literal, Any +from typing import cast, List, Dict, Union, Optional, Literal, Any, BinaryIO from .caching import Cache from concurrent.futures import ThreadPoolExecutor @@ -790,6 +789,38 @@ class ImageResponse(OpenAIObject): return self.dict() +class TranscriptionResponse(OpenAIObject): + text: Optional[str] = None + + _hidden_params: dict = {} + + def __init__(self, text=None): + super().__init__(text=text) + + def __contains__(self, key): + # Define custom behavior for the 'in' operator + return hasattr(self, key) + + def get(self, key, default=None): + # Custom .get() method to access attributes with a default value if the attribute doesn't exist + return getattr(self, key, default) + + def __getitem__(self, key): + # Allow dictionary-style access to attributes + return getattr(self, key) + + def __setitem__(self, key, value): + # Allow dictionary-style assignment of attributes + setattr(self, key, value) + + def json(self, **kwargs): + try: + return self.model_dump() # noqa + except: + # if using pydantic v1 + return self.dict() + + ############################################################ def print_verbose(print_statement, logger_only: bool = False): try: @@ -815,6 +846,8 @@ class CallTypes(Enum): aimage_generation = "aimage_generation" moderation = "moderation" amoderation = "amoderation" + atranscription = "atranscription" + transcription = "transcription" # Logging function -> log the exact model details + what's being sent | Non-BlockingP @@ -2271,6 +2304,12 @@ def client(original_function): or call_type == CallTypes.text_completion.value ): messages = args[0] if len(args) > 0 else kwargs["prompt"] + elif ( + call_type == CallTypes.atranscription.value + or call_type == CallTypes.transcription.value + ): + _file_name: BinaryIO = args[1] if len(args) > 1 else kwargs["file"] + messages = _file_name.name stream = True if "stream" in kwargs and kwargs["stream"] == True else False logging_obj = Logging( model=model, @@ -6135,10 +6174,10 @@ def convert_to_streaming_response(response_object: Optional[dict] = None): def convert_to_model_response_object( response_object: Optional[dict] = None, model_response_object: Optional[ - Union[ModelResponse, EmbeddingResponse, ImageResponse] + Union[ModelResponse, EmbeddingResponse, ImageResponse, TranscriptionResponse] ] = None, response_type: Literal[ - "completion", "embedding", "image_generation" + "completion", "embedding", "image_generation", "audio_transcription" ] = "completion", stream=False, start_time=None, @@ -6249,6 +6288,19 @@ def convert_to_model_response_object( model_response_object.data = response_object["data"] return model_response_object + elif response_type == "audio_transcription" and ( + model_response_object is None + or isinstance(model_response_object, TranscriptionResponse) + ): + if response_object is None: + raise Exception("Error in response object format") + + if model_response_object is None: + model_response_object = TranscriptionResponse() + + if "text" in response_object: + model_response_object.text = response_object["text"] + return model_response_object except Exception as e: raise Exception(f"Invalid response object {traceback.format_exc()}") diff --git a/model_prices_and_context_window.json b/model_prices_and_context_window.json index d56450b23..18c4b0d9a 100644 --- a/model_prices_and_context_window.json +++ b/model_prices_and_context_window.json @@ -293,6 +293,18 @@ "output_cost_per_pixel": 0.0, "litellm_provider": "openai" }, + "whisper-1": { + "mode": "audio_transcription", + "input_cost_per_second": 0, + "output_cost_per_second": 0.0001, + "litellm_provider": "openai" + }, + "azure/whisper-1": { + "mode": "audio_transcription", + "input_cost_per_second": 0, + "output_cost_per_second": 0.0001, + "litellm_provider": "azure" + }, "azure/gpt-4-0125-preview": { "max_tokens": 128000, "max_input_tokens": 128000, diff --git a/tests/gettysburg.wav b/tests/gettysburg.wav new file mode 100644 index 0000000000000000000000000000000000000000..9690f521e8443f3b0db97b1467a9d1fe85d964c7 GIT binary patch literal 775192 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ΞBV<~GHWu9u9fV*7M#DQWi(FaE3d2x#L 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 z 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‎B@%(x7he3Lf!S<|1CFR{A70S5Zio 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%0DXEd0Y2UxCk-Xxy@_O5wb8l0_H)GYU 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

^eD2KE6C?O@`Ui|+t?-&5^N3{t_7SO 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

C}73IHV_hZC$?AUdcefS7Jq^HbtaSeVO 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%0D0?Gv?e&@sG?YV6eti0ei3810Vl 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 HLiFXo&2)c3 literal 0 HcmV?d00001 diff --git a/tests/test_whisper.py b/tests/test_whisper.py new file mode 100644 index 000000000..8ee3b428c --- /dev/null +++ b/tests/test_whisper.py @@ -0,0 +1,26 @@ +# What is this? +## Tests `litellm.transcription` endpoint +import pytest +import asyncio, time +import aiohttp +from openai import AsyncOpenAI +import sys, os, dotenv +from typing import Optional +from dotenv import load_dotenv + +audio_file = open("./gettysburg.wav", "rb") + +load_dotenv() + +sys.path.insert( + 0, os.path.abspath("../") +) # Adds the parent directory to the system path +import litellm + + +def test_transcription(): + transcript = litellm.transcription(model="whisper-1", file=audio_file) + print(f"transcript: {transcript}") + + +test_transcription() From a6930454604fe6ffef6b9016f43278e6b01cf83c Mon Sep 17 00:00:00 2001 From: Guillermo Date: Fri, 8 Mar 2024 20:33:47 +0100 Subject: [PATCH 21/74] docs: fix yaml typo in proxy/configs.md equals was used instead of : as key-value delimiter in yaml --- docs/my-website/docs/proxy/configs.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/my-website/docs/proxy/configs.md b/docs/my-website/docs/proxy/configs.md index 5745685de..a863ec2ca 100644 --- a/docs/my-website/docs/proxy/configs.md +++ b/docs/my-website/docs/proxy/configs.md @@ -49,9 +49,9 @@ model_list: rpm: 6 - model_name: anthropic-claude litellm_params: - model="bedrock/anthropic.claude-instant-v1" + model: bedrock/anthropic.claude-instant-v1 ### [OPTIONAL] SET AWS REGION ### - aws_region_name="us-east-1" + aws_region_name: us-east-1 - model_name: vllm-models litellm_params: model: openai/facebook/opt-125m # the `openai/` prefix tells litellm it's openai compatible From 2aafbe390b80748edbd67e31935af17375a21dc2 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 13:16:12 -0800 Subject: [PATCH 22/74] (feat) read passed api_version --- litellm/proxy/proxy_server.py | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/litellm/proxy/proxy_server.py b/litellm/proxy/proxy_server.py index 19ac5c961..d9642b810 100644 --- a/litellm/proxy/proxy_server.py +++ b/litellm/proxy/proxy_server.py @@ -2670,6 +2670,11 @@ async def chat_completion( except: data = json.loads(body_str) + # Azure OpenAI only: check if user passed api-version + query_params = dict(request.query_params) + if "api-version" in query_params: + data["api_version"] = query_params["api-version"] + # Include original request and headers in the data data["proxy_server_request"] = { "url": str(request.url), From d67c63b0c3f13215b91e5c0fa9719b1e97ac8427 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 13:33:58 -0800 Subject: [PATCH 23/74] (fix) use azure api_version --- litellm/llms/azure.py | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/litellm/llms/azure.py b/litellm/llms/azure.py index 01b54987b..6a0c1ec1f 100644 --- a/litellm/llms/azure.py +++ b/litellm/llms/azure.py @@ -333,10 +333,17 @@ class AzureChatCompletion(BaseLLM): azure_client_params["api_key"] = api_key elif azure_ad_token is not None: azure_client_params["azure_ad_token"] = azure_ad_token + + # setting Azure client if client is None: azure_client = AsyncAzureOpenAI(**azure_client_params) else: azure_client = client + if api_version is not None and isinstance( + azure_client._custom_query, dict + ): + # set api_version to version passed by user + azure_client._custom_query.setdefault("api-version", api_version) ## LOGGING logging_obj.pre_call( input=data["messages"], From 2f6e15655a093777b912e59f92ee78a3cfc6acc6 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 13:38:29 -0800 Subject: [PATCH 24/74] (feat) set api_version for Azure --- litellm/llms/azure.py | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/litellm/llms/azure.py b/litellm/llms/azure.py index 6a0c1ec1f..9f5b04a04 100644 --- a/litellm/llms/azure.py +++ b/litellm/llms/azure.py @@ -270,6 +270,14 @@ class AzureChatCompletion(BaseLLM): azure_client = AzureOpenAI(**azure_client_params) else: azure_client = client + if api_version is not None and isinstance( + azure_client._custom_query, dict + ): + # set api_version to version passed by user + azure_client._custom_query.setdefault( + "api-version", api_version + ) + response = azure_client.chat.completions.create(**data, timeout=timeout) # type: ignore stringified_response = response.model_dump() ## LOGGING @@ -408,6 +416,10 @@ class AzureChatCompletion(BaseLLM): azure_client = AzureOpenAI(**azure_client_params) else: azure_client = client + azure_client = client + if api_version is not None and isinstance(azure_client._custom_query, dict): + # set api_version to version passed by user + azure_client._custom_query.setdefault("api-version", api_version) ## LOGGING logging_obj.pre_call( input=data["messages"], @@ -461,6 +473,11 @@ class AzureChatCompletion(BaseLLM): azure_client = AsyncAzureOpenAI(**azure_client_params) else: azure_client = client + if api_version is not None and isinstance( + azure_client._custom_query, dict + ): + # set api_version to version passed by user + azure_client._custom_query.setdefault("api-version", api_version) ## LOGGING logging_obj.pre_call( input=data["messages"], From 65ccfc35ca5b5de0386b4fd6b432d1c351b7d4e5 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 13:44:39 -0800 Subject: [PATCH 25/74] (fix) azure extra setting client --- litellm/llms/azure.py | 1 - 1 file changed, 1 deletion(-) diff --git a/litellm/llms/azure.py b/litellm/llms/azure.py index 9f5b04a04..0f6786902 100644 --- a/litellm/llms/azure.py +++ b/litellm/llms/azure.py @@ -415,7 +415,6 @@ class AzureChatCompletion(BaseLLM): if client is None: azure_client = AzureOpenAI(**azure_client_params) else: - azure_client = client azure_client = client if api_version is not None and isinstance(azure_client._custom_query, dict): # set api_version to version passed by user From 6b1049217e8df6a14f84121b643fea75ddf28c8e Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 13:48:38 -0800 Subject: [PATCH 26/74] feat(azure.py): add support for calling whisper endpoints on azure --- litellm/llms/azure.py | 111 +++++++++++++++++++++++++++++++++++++++++- litellm/main.py | 88 +++++++++++++++++++++++++++++---- tests/test_whisper.py | 51 ++++++++++++++++++- 3 files changed, 237 insertions(+), 13 deletions(-) diff --git a/litellm/llms/azure.py b/litellm/llms/azure.py index 01b54987b..e19023b03 100644 --- a/litellm/llms/azure.py +++ b/litellm/llms/azure.py @@ -7,8 +7,9 @@ from litellm.utils import ( Message, CustomStreamWrapper, convert_to_model_response_object, + TranscriptionResponse, ) -from typing import Callable, Optional +from typing import Callable, Optional, BinaryIO from litellm import OpenAIConfig import litellm, json import httpx @@ -757,6 +758,114 @@ class AzureChatCompletion(BaseLLM): else: raise AzureOpenAIError(status_code=500, message=str(e)) + def audio_transcriptions( + self, + model: str, + audio_file: BinaryIO, + optional_params: dict, + model_response: TranscriptionResponse, + timeout: float, + api_key: Optional[str] = None, + api_base: Optional[str] = None, + api_version: Optional[str] = None, + client=None, + azure_ad_token: Optional[str] = None, + max_retries=None, + logging_obj=None, + atranscriptions: bool = False, + ): + data = {"model": model, "file": audio_file, **optional_params} + + # init AzureOpenAI Client + azure_client_params = { + "api_version": api_version, + "azure_endpoint": api_base, + "azure_deployment": model, + "max_retries": max_retries, + "timeout": timeout, + } + azure_client_params = select_azure_base_url_or_endpoint( + azure_client_params=azure_client_params + ) + if api_key is not None: + azure_client_params["api_key"] = api_key + elif azure_ad_token is not None: + azure_client_params["azure_ad_token"] = azure_ad_token + + if atranscriptions == True: + return self.async_audio_transcriptions( + audio_file=audio_file, + data=data, + model_response=model_response, + timeout=timeout, + api_key=api_key, + api_base=api_base, + client=client, + azure_client_params=azure_client_params, + max_retries=max_retries, + logging_obj=logging_obj, + ) + if client is None: + azure_client = AzureOpenAI(http_client=litellm.client_session, **azure_client_params) # type: ignore + else: + azure_client = client + response = azure_client.audio.transcriptions.create( + **data, timeout=timeout # type: ignore + ) + stringified_response = response.model_dump() + ## LOGGING + logging_obj.post_call( + input=audio_file.name, + api_key=api_key, + additional_args={"complete_input_dict": data}, + original_response=stringified_response, + ) + final_response = convert_to_model_response_object(response_object=stringified_response, model_response_object=model_response, response_type="audio_transcription") # type: ignore + return final_response + + async def async_audio_transcriptions( + self, + audio_file: BinaryIO, + data: dict, + model_response: TranscriptionResponse, + timeout: float, + api_key: Optional[str] = None, + api_base: Optional[str] = None, + client=None, + azure_client_params=None, + max_retries=None, + logging_obj=None, + ): + response = None + try: + if client is None: + async_azure_client = AsyncAzureOpenAI( + **azure_client_params, + http_client=litellm.aclient_session, + ) + else: + async_azure_client = client + response = await async_azure_client.audio.transcriptions.create( + **data, timeout=timeout + ) # type: ignore + stringified_response = response.model_dump() + ## LOGGING + logging_obj.post_call( + input=audio_file.name, + api_key=api_key, + additional_args={"complete_input_dict": data}, + original_response=stringified_response, + ) + return convert_to_model_response_object(response_object=stringified_response, model_response_object=model_response, response_type="image_generation") # type: ignore + except Exception as e: + ## LOGGING + logging_obj.post_call( + input=input, + api_key=api_key, + original_response=str(e), + ) + raise e + async def ahealth_check( self, model: Optional[str], diff --git a/litellm/main.py b/litellm/main.py index 2df9686fe..f1a745fcc 100644 --- a/litellm/main.py +++ b/litellm/main.py @@ -88,6 +88,7 @@ from litellm.utils import ( read_config_args, Choices, Message, + TranscriptionResponse, ) ####### ENVIRONMENT VARIABLES ################### @@ -3065,11 +3066,11 @@ async def aimage_generation(*args, **kwargs): Asynchronously calls the `image_generation` function with the given arguments and keyword arguments. Parameters: - - `args` (tuple): Positional arguments to be passed to the `embedding` function. - - `kwargs` (dict): Keyword arguments to be passed to the `embedding` function. + - `args` (tuple): Positional arguments to be passed to the `image_generation` function. + - `kwargs` (dict): Keyword arguments to be passed to the `image_generation` function. Returns: - - `response` (Any): The response returned by the `embedding` function. + - `response` (Any): The response returned by the `image_generation` function. """ loop = asyncio.get_event_loop() model = args[0] if len(args) > 0 else kwargs["model"] @@ -3091,7 +3092,7 @@ async def aimage_generation(*args, **kwargs): # Await normally init_response = await loop.run_in_executor(None, func_with_context) if isinstance(init_response, dict) or isinstance( - init_response, ModelResponse + init_response, ImageResponse ): ## CACHING SCENARIO response = init_response elif asyncio.iscoroutine(init_response): @@ -3318,7 +3319,43 @@ async def atranscription(*args, **kwargs): Allows router to load balance between them """ - pass + loop = asyncio.get_event_loop() + model = args[0] if len(args) > 0 else kwargs["model"] + ### PASS ARGS TO Image Generation ### + kwargs["atranscription"] = True + custom_llm_provider = None + try: + # Use a partial function to pass your keyword arguments + func = partial(transcription, *args, **kwargs) + + # Add the context to the function + ctx = contextvars.copy_context() + func_with_context = partial(ctx.run, func) + + _, custom_llm_provider, _, _ = get_llm_provider( + model=model, api_base=kwargs.get("api_base", None) + ) + + # Await normally + init_response = await loop.run_in_executor(None, func_with_context) + if isinstance(init_response, dict) or isinstance( + init_response, TranscriptionResponse + ): ## CACHING SCENARIO + response = init_response + elif asyncio.iscoroutine(init_response): + response = await init_response + else: + # Call the synchronous function using run_in_executor + response = await loop.run_in_executor(None, func_with_context) + return response + except Exception as e: + custom_llm_provider = custom_llm_provider or "openai" + raise exception_type( + model=model, + custom_llm_provider=custom_llm_provider, + original_exception=e, + completion_kwargs=args, + ) @client @@ -3356,8 +3393,7 @@ def transcription( model_response = litellm.utils.TranscriptionResponse() - # model, custom_llm_provider, dynamic_api_key, api_base = get_llm_provider(model=model, custom_llm_provider=custom_llm_provider, api_base=api_base) # type: ignore - custom_llm_provider = "openai" + model, custom_llm_provider, dynamic_api_key, api_base = get_llm_provider(model=model, custom_llm_provider=custom_llm_provider, api_base=api_base) # type: ignore optional_params = { "language": language, @@ -3365,8 +3401,40 @@ def transcription( "response_format": response_format, "temperature": None, # openai defaults this to 0 } - if custom_llm_provider == "openai": - return openai_chat_completions.audio_transcriptions( + + if custom_llm_provider == "azure": + # azure configs + api_base = api_base or litellm.api_base or get_secret("AZURE_API_BASE") + + api_version = ( + api_version or litellm.api_version or get_secret("AZURE_API_VERSION") + ) + + azure_ad_token = kwargs.pop("azure_ad_token", None) or get_secret( + "AZURE_AD_TOKEN" + ) + + api_key = ( + api_key + or litellm.api_key + or litellm.azure_key + or get_secret("AZURE_API_KEY") + ) + response = azure_chat_completions.audio_transcriptions( + model=model, + audio_file=file, + optional_params=optional_params, + model_response=model_response, + atranscriptions=atranscriptions, + timeout=timeout, + logging_obj=litellm_logging_obj, + api_base=api_base, + api_key=api_key, + api_version=api_version, + azure_ad_token=azure_ad_token, + ) + elif custom_llm_provider == "openai": + response = openai_chat_completions.audio_transcriptions( model=model, audio_file=file, optional_params=optional_params, @@ -3375,7 +3443,7 @@ def transcription( timeout=timeout, logging_obj=litellm_logging_obj, ) - return + return response ##### Health Endpoints ####################### diff --git a/tests/test_whisper.py b/tests/test_whisper.py index 8ee3b428c..9d8f038c2 100644 --- a/tests/test_whisper.py +++ b/tests/test_whisper.py @@ -19,8 +19,55 @@ import litellm def test_transcription(): - transcript = litellm.transcription(model="whisper-1", file=audio_file) + transcript = litellm.transcription( + model="whisper-1", + file=audio_file, + ) print(f"transcript: {transcript}") -test_transcription() +# test_transcription() + + +def test_transcription_azure(): + transcript = litellm.transcription( + model="azure/azure-whisper", + file=audio_file, + api_base=os.getenv("AZURE_EUROPE_API_BASE"), + api_key=os.getenv("AZURE_EUROPE_API_KEY"), + api_version=os.getenv("2024-02-15-preview"), + ) + + assert transcript.text is not None + assert isinstance(transcript.text, str) + + +# test_transcription_azure() + + +@pytest.mark.asyncio +async def test_transcription_async_azure(): + transcript = await litellm.atranscription( + model="azure/azure-whisper", + file=audio_file, + api_base=os.getenv("AZURE_EUROPE_API_BASE"), + api_key=os.getenv("AZURE_EUROPE_API_KEY"), + api_version=os.getenv("2024-02-15-preview"), + ) + + assert transcript.text is not None + assert isinstance(transcript.text, str) + + +# asyncio.run(test_transcription_async_azure()) + + +@pytest.mark.asyncio +async def test_transcription_async_openai(): + transcript = await litellm.atranscription( + model="whisper-1", + file=audio_file, + ) + + assert transcript.text is not None + assert isinstance(transcript.text, str) From 321769a74dbaa2c8d7dd94688a64a568f235c883 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 13:50:34 -0800 Subject: [PATCH 27/74] build(model_prices_and_context_window.json): add pricing for whisper endpoints (openai + azure) --- litellm/model_prices_and_context_window_backup.json | 12 ++++++++++++ model_prices_and_context_window.json | 12 ++++++++++++ 2 files changed, 24 insertions(+) diff --git a/litellm/model_prices_and_context_window_backup.json b/litellm/model_prices_and_context_window_backup.json index d56450b23..18c4b0d9a 100644 --- a/litellm/model_prices_and_context_window_backup.json +++ b/litellm/model_prices_and_context_window_backup.json @@ -293,6 +293,18 @@ "output_cost_per_pixel": 0.0, "litellm_provider": "openai" }, + "whisper-1": { + "mode": "audio_transcription", + "input_cost_per_second": 0, + "output_cost_per_second": 0.0001, + "litellm_provider": "openai" + }, + "azure/whisper-1": { + "mode": "audio_transcription", + "input_cost_per_second": 0, + "output_cost_per_second": 0.0001, + "litellm_provider": "azure" + }, "azure/gpt-4-0125-preview": { "max_tokens": 128000, "max_input_tokens": 128000, diff --git a/model_prices_and_context_window.json b/model_prices_and_context_window.json index d56450b23..18c4b0d9a 100644 --- a/model_prices_and_context_window.json +++ b/model_prices_and_context_window.json @@ -293,6 +293,18 @@ "output_cost_per_pixel": 0.0, "litellm_provider": "openai" }, + "whisper-1": { + "mode": "audio_transcription", + "input_cost_per_second": 0, + "output_cost_per_second": 0.0001, + "litellm_provider": "openai" + }, + "azure/whisper-1": { + "mode": "audio_transcription", + "input_cost_per_second": 0, + "output_cost_per_second": 0.0001, + "litellm_provider": "azure" + }, "azure/gpt-4-0125-preview": { "max_tokens": 128000, "max_input_tokens": 128000, From ae54b398d29c773b5a89a6cf7b0396d97f8ac370 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 13:58:15 -0800 Subject: [PATCH 28/74] feat(router.py): add load balancing for async transcription calls --- litellm/main.py | 1 + litellm/router.py | 80 ++++++++++++++++++++++++++++++++++++++++++++++- 2 files changed, 80 insertions(+), 1 deletion(-) diff --git a/litellm/main.py b/litellm/main.py index f1a745fcc..a04dba4ec 100644 --- a/litellm/main.py +++ b/litellm/main.py @@ -3313,6 +3313,7 @@ def image_generation( ##### Transcription ####################### +@client async def atranscription(*args, **kwargs): """ Calls openai + azure whisper endpoints. diff --git a/litellm/router.py b/litellm/router.py index d4c0be862..10f7058b3 100644 --- a/litellm/router.py +++ b/litellm/router.py @@ -9,7 +9,7 @@ import copy, httpx from datetime import datetime -from typing import Dict, List, Optional, Union, Literal, Any +from typing import Dict, List, Optional, Union, Literal, Any, BinaryIO import random, threading, time, traceback, uuid import litellm, openai from litellm.caching import RedisCache, InMemoryCache, DualCache @@ -633,6 +633,84 @@ class Router: self.fail_calls[model_name] += 1 raise e + async def atranscription(self, file: BinaryIO, model: str, **kwargs): + try: + kwargs["model"] = model + kwargs["file"] = file + kwargs["original_function"] = self._atranscription + kwargs["num_retries"] = kwargs.get("num_retries", self.num_retries) + timeout = kwargs.get("request_timeout", self.timeout) + kwargs.setdefault("metadata", {}).update({"model_group": model}) + response = await self.async_function_with_fallbacks(**kwargs) + + return response + except Exception as e: + raise e + + async def _atranscription(self, file: BinaryIO, model: str, **kwargs): + try: + verbose_router_logger.debug( + f"Inside _atranscription()- model: {model}; kwargs: {kwargs}" + ) + deployment = self.get_available_deployment( + model=model, + messages=[{"role": "user", "content": "prompt"}], + specific_deployment=kwargs.pop("specific_deployment", None), + ) + kwargs.setdefault("metadata", {}).update( + { + "deployment": deployment["litellm_params"]["model"], + "model_info": deployment.get("model_info", {}), + } + ) + kwargs["model_info"] = deployment.get("model_info", {}) + data = deployment["litellm_params"].copy() + model_name = data["model"] + for k, v in self.default_litellm_params.items(): + if ( + k not in kwargs + ): # prioritize model-specific params > default router params + kwargs[k] = v + elif k == "metadata": + kwargs[k].update(v) + + potential_model_client = self._get_client( + deployment=deployment, kwargs=kwargs, client_type="async" + ) + # check if provided keys == client keys # + dynamic_api_key = kwargs.get("api_key", None) + if ( + dynamic_api_key is not None + and potential_model_client is not None + and dynamic_api_key != potential_model_client.api_key + ): + model_client = None + else: + model_client = potential_model_client + + self.total_calls[model_name] += 1 + response = await litellm.atranscription( + **{ + **data, + "file": file, + "caching": self.cache_responses, + "client": model_client, + **kwargs, + } + ) + self.success_calls[model_name] += 1 + verbose_router_logger.info( + f"litellm.atranscription(model={model_name})\033[32m 200 OK\033[0m" + ) + return response + except Exception as e: + verbose_router_logger.info( + f"litellm.atranscription(model={model_name})\033[31m Exception {str(e)}\033[0m" + ) + if model_name is not None: + self.fail_calls[model_name] += 1 + raise e + async def amoderation(self, model: str, input: str, **kwargs): try: kwargs["model"] = model From 6fa585d001d6c1ed5cf3ee2812f407186554da32 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 14:02:34 -0800 Subject: [PATCH 29/74] test(test_whisper.py): fix test --- tests/test_whisper.py | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/tests/test_whisper.py b/tests/test_whisper.py index 9d8f038c2..9090f42d6 100644 --- a/tests/test_whisper.py +++ b/tests/test_whisper.py @@ -8,7 +8,11 @@ import sys, os, dotenv from typing import Optional from dotenv import load_dotenv -audio_file = open("./gettysburg.wav", "rb") +pwd = os.getcwd() +print(pwd) + +file_path = os.path.join(pwd, "gettysburg.wav") +audio_file = open(file_path, "rb") load_dotenv() From 9274245a0b6f178d0d83fc14b9f618f332413a2c Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 14:10:19 -0800 Subject: [PATCH 30/74] test(test_whisper.py): fix getting path for audio file in test --- tests/test_whisper.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/tests/test_whisper.py b/tests/test_whisper.py index 9090f42d6..78e885ad3 100644 --- a/tests/test_whisper.py +++ b/tests/test_whisper.py @@ -8,7 +8,8 @@ import sys, os, dotenv from typing import Optional from dotenv import load_dotenv -pwd = os.getcwd() +# Get the current directory of the file being run +pwd = os.path.dirname(os.path.realpath(__file__)) print(pwd) file_path = os.path.join(pwd, "gettysburg.wav") From fe125a5131cd73321791adc79d84498c5dbf20d3 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 14:19:37 -0800 Subject: [PATCH 31/74] test(test_whisper.py): add testing for load balancing whisper endpoints on router --- litellm/router.py | 22 ++++++++++++++++++++ tests/test_whisper.py | 47 ++++++++++++++++++++++++++++++++++++++++--- 2 files changed, 66 insertions(+), 3 deletions(-) diff --git a/litellm/router.py b/litellm/router.py index 10f7058b3..71339aa36 100644 --- a/litellm/router.py +++ b/litellm/router.py @@ -634,6 +634,28 @@ class Router: raise e async def atranscription(self, file: BinaryIO, model: str, **kwargs): + """ + Example Usage: + + ``` + from litellm import Router + client = Router(model_list = [ + { + "model_name": "whisper", + "litellm_params": { + "model": "whisper-1", + }, + }, + ]) + + audio_file = open("speech.mp3", "rb") + transcript = await client.atranscription( + model="whisper", + file=audio_file + ) + + ``` + """ try: kwargs["model"] = model kwargs["file"] = file diff --git a/tests/test_whisper.py b/tests/test_whisper.py index 9d8f038c2..bb0971732 100644 --- a/tests/test_whisper.py +++ b/tests/test_whisper.py @@ -1,14 +1,20 @@ # What is this? -## Tests `litellm.transcription` endpoint +## Tests `litellm.transcription` endpoint. Outside litellm module b/c of audio file used in testing (it's ~700kb). + import pytest import asyncio, time -import aiohttp +import aiohttp, traceback from openai import AsyncOpenAI import sys, os, dotenv from typing import Optional from dotenv import load_dotenv -audio_file = open("./gettysburg.wav", "rb") +pwd = os.path.dirname(os.path.realpath(__file__)) +print(pwd) + +file_path = os.path.join(pwd, "gettysburg.wav") + +audio_file = open(file_path, "rb") load_dotenv() @@ -16,6 +22,7 @@ sys.path.insert( 0, os.path.abspath("../") ) # Adds the parent directory to the system path import litellm +from litellm import Router def test_transcription(): @@ -71,3 +78,37 @@ async def test_transcription_async_openai(): assert transcript.text is not None assert isinstance(transcript.text, str) + + +@pytest.mark.asyncio +async def test_transcription_on_router(): + litellm.set_verbose = True + print("\n Testing async transcription on router\n") + try: + model_list = [ + { + "model_name": "whisper", + "litellm_params": { + "model": "whisper-1", + }, + }, + { + "model_name": "whisper", + "litellm_params": { + "model": "azure/azure-whisper", + "api_base": os.getenv("AZURE_EUROPE_API_BASE"), + "api_key": os.getenv("AZURE_EUROPE_API_KEY"), + "api_version": os.getenv("2024-02-15-preview"), + }, + }, + ] + + router = Router(model_list=model_list) + response = await router.atranscription( + model="whisper", + file=audio_file, + ) + print(response) + except Exception as e: + traceback.print_exc() + pytest.fail(f"Error occurred: {e}") From 8c6d5b7f16549b740b4f7c2739f224ab29295fa0 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 14:28:07 -0800 Subject: [PATCH 32/74] feat(proxy_server.py): supports `/audio/transcription` endpoint on proxy --- litellm/proxy/proxy_server.py | 147 ++++++++++++++++++++++++++++++++++ 1 file changed, 147 insertions(+) diff --git a/litellm/proxy/proxy_server.py b/litellm/proxy/proxy_server.py index 19ac5c961..c90f14a97 100644 --- a/litellm/proxy/proxy_server.py +++ b/litellm/proxy/proxy_server.py @@ -3213,6 +3213,153 @@ async def image_generation( ) +@router.post( + "/v1/audio/transcriptions", + dependencies=[Depends(user_api_key_auth)], + response_class=ORJSONResponse, + tags=["image generation"], +) +@router.post( + "/audio/transcriptions", + dependencies=[Depends(user_api_key_auth)], + response_class=ORJSONResponse, + tags=["image generation"], +) +async def audio_transcriptions( + request: Request, + user_api_key_dict: UserAPIKeyAuth = Depends(user_api_key_auth), +): + """ + Same params as: + + https://platform.openai.com/docs/api-reference/audio/createTranscription?lang=curl + """ + global proxy_logging_obj + try: + # Use orjson to parse JSON data, orjson speeds up requests significantly + body = await request.body() + data = orjson.loads(body) + + # Include original request and headers in the data + data["proxy_server_request"] = { + "url": str(request.url), + "method": request.method, + "headers": dict(request.headers), + "body": copy.copy(data), # use copy instead of deepcopy + } + + if data.get("user", None) is None and user_api_key_dict.user_id is not None: + data["user"] = user_api_key_dict.user_id + + data["model"] = ( + general_settings.get("moderation_model", None) # server default + or user_model # model name passed via cli args + or data["model"] # default passed in http request + ) + if user_model: + data["model"] = user_model + + if "metadata" not in data: + data["metadata"] = {} + data["metadata"]["user_api_key"] = user_api_key_dict.api_key + data["metadata"]["user_api_key_metadata"] = user_api_key_dict.metadata + _headers = dict(request.headers) + _headers.pop( + "authorization", None + ) # do not store the original `sk-..` api key in the db + data["metadata"]["headers"] = _headers + data["metadata"]["user_api_key_alias"] = getattr( + user_api_key_dict, "key_alias", None + ) + data["metadata"]["user_api_key_user_id"] = user_api_key_dict.user_id + data["metadata"]["user_api_key_team_id"] = getattr( + user_api_key_dict, "team_id", None + ) + data["metadata"]["endpoint"] = str(request.url) + + ### TEAM-SPECIFIC PARAMS ### + if user_api_key_dict.team_id is not None: + team_config = await proxy_config.load_team_config( + team_id=user_api_key_dict.team_id + ) + if len(team_config) == 0: + pass + else: + team_id = team_config.pop("team_id", None) + data["metadata"]["team_id"] = team_id + data = { + **team_config, + **data, + } # add the team-specific configs to the completion call + + router_model_names = ( + [m["model_name"] for m in llm_model_list] + if llm_model_list is not None + else [] + ) + + ### CALL HOOKS ### - modify incoming data / reject request before calling the model + data = await proxy_logging_obj.pre_call_hook( + user_api_key_dict=user_api_key_dict, data=data, call_type="moderation" + ) + + start_time = time.time() + + ## ROUTE TO CORRECT ENDPOINT ## + # skip router if user passed their key + if "api_key" in data: + response = await litellm.atranscription(**data) + elif ( + llm_router is not None and data["model"] in router_model_names + ): # model in router model list + response = await llm_router.atranscription(**data) + elif ( + llm_router is not None and data["model"] in llm_router.deployment_names + ): # model in router deployments, calling a specific deployment on the router + response = await llm_router.atranscription(**data, specific_deployment=True) + elif ( + llm_router is not None + and llm_router.model_group_alias is not None + and data["model"] in llm_router.model_group_alias + ): # model set in model_group_alias + response = await llm_router.atranscription( + **data + ) # ensure this goes the llm_router, router will do the correct alias mapping + elif user_model is not None: # `litellm --model ` + response = await litellm.atranscription(**data) + else: + raise HTTPException( + status_code=status.HTTP_400_BAD_REQUEST, + detail={"error": "Invalid model name passed in"}, + ) + + ### ALERTING ### + data["litellm_status"] = "success" # used for alerting + + return response + except Exception as e: + await proxy_logging_obj.post_call_failure_hook( + user_api_key_dict=user_api_key_dict, original_exception=e + ) + traceback.print_exc() + if isinstance(e, HTTPException): + raise ProxyException( + message=getattr(e, "message", str(e)), + type=getattr(e, "type", "None"), + param=getattr(e, "param", "None"), + code=getattr(e, "status_code", status.HTTP_400_BAD_REQUEST), + ) + else: + error_traceback = traceback.format_exc() + error_msg = f"{str(e)}\n\n{error_traceback}" + raise ProxyException( + message=getattr(e, "message", error_msg), + type=getattr(e, "type", "None"), + param=getattr(e, "param", "None"), + code=getattr(e, "status_code", 500), + ) + + @router.post( "/v1/moderations", dependencies=[Depends(user_api_key_auth)], From cc0294b2f2346c0870b446112dc1fdc9826e1676 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 14:29:31 -0800 Subject: [PATCH 33/74] fix(proxy_server.py): fix tagging of endpoints --- litellm/proxy/proxy_server.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/litellm/proxy/proxy_server.py b/litellm/proxy/proxy_server.py index c90f14a97..27eeea573 100644 --- a/litellm/proxy/proxy_server.py +++ b/litellm/proxy/proxy_server.py @@ -3066,13 +3066,13 @@ async def embeddings( "/v1/images/generations", dependencies=[Depends(user_api_key_auth)], response_class=ORJSONResponse, - tags=["image generation"], + tags=["images"], ) @router.post( "/images/generations", dependencies=[Depends(user_api_key_auth)], response_class=ORJSONResponse, - tags=["image generation"], + tags=["images"], ) async def image_generation( request: Request, @@ -3217,13 +3217,13 @@ async def image_generation( "/v1/audio/transcriptions", dependencies=[Depends(user_api_key_auth)], response_class=ORJSONResponse, - tags=["image generation"], + tags=["audio"], ) @router.post( "/audio/transcriptions", dependencies=[Depends(user_api_key_auth)], response_class=ORJSONResponse, - tags=["image generation"], + tags=["audio"], ) async def audio_transcriptions( request: Request, From 2d71f54afbb2a29d9ceb7783524c7e39ad22e366 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 15:18:06 -0800 Subject: [PATCH 34/74] (docs) load test litellm --- docs/my-website/docs/load_test.md | 82 ++++++++++++++++++++++++++- docs/my-website/docs/proxy/deploy.md | 14 ----- docs/my-website/img/locust.png | Bin 0 -> 111279 bytes 3 files changed, 81 insertions(+), 15 deletions(-) create mode 100644 docs/my-website/img/locust.png diff --git a/docs/my-website/docs/load_test.md b/docs/my-website/docs/load_test.md index f568b5696..94165fb7b 100644 --- a/docs/my-website/docs/load_test.md +++ b/docs/my-website/docs/load_test.md @@ -1,5 +1,84 @@ +import Image from '@theme/IdealImage'; + # 🔥 Load Test LiteLLM +## Load Test LiteLLM Proxy - 1500+ req/s + +## 1500+ concurrent requests/s + +LiteLLM proxy has been load tested to handle 1500+ concurrent req/s + +```python +import time, asyncio +from openai import AsyncOpenAI, AsyncAzureOpenAI +import uuid +import traceback + +# base_url - litellm proxy endpoint +# api_key - litellm proxy api-key, is created proxy with auth +litellm_client = AsyncOpenAI(base_url="http://0.0.0.0:4000", api_key="sk-1234") + + +async def litellm_completion(): + # Your existing code for litellm_completion goes here + try: + response = await litellm_client.chat.completions.create( + model="azure-gpt-3.5", + messages=[{"role": "user", "content": f"This is a test: {uuid.uuid4()}"}], + ) + print(response) + return response + + except Exception as e: + # If there's an exception, log the error message + with open("error_log.txt", "a") as error_log: + error_log.write(f"Error during completion: {str(e)}\n") + pass + + +async def main(): + for i in range(1): + start = time.time() + n = 1500 # Number of concurrent tasks + tasks = [litellm_completion() for _ in range(n)] + + chat_completions = await asyncio.gather(*tasks) + + successful_completions = [c for c in chat_completions if c is not None] + + # Write errors to error_log.txt + with open("error_log.txt", "a") as error_log: + for completion in chat_completions: + if isinstance(completion, str): + error_log.write(completion + "\n") + + print(n, time.time() - start, len(successful_completions)) + time.sleep(10) + + +if __name__ == "__main__": + # Blank out contents of error_log.txt + open("error_log.txt", "w").close() + + asyncio.run(main()) + +``` + +### Throughput - 30% Increase +LiteLLM proxy + Load Balancer gives **30% increase** in throughput compared to Raw OpenAI API + + +### Latency Added - 0.00325 seconds +LiteLLM proxy adds **0.00325 seconds** latency as compared to using the Raw OpenAI API + + + +### Testing LiteLLM Proxy with Locust +- 1 LiteLLM container can handle ~140 requests/second with 0.4 failures + + + +## Load Test LiteLLM SDK vs OpenAI Here is a script to load test LiteLLM vs OpenAI ```python @@ -84,4 +163,5 @@ async def loadtest_fn(): # Run the event loop to execute the async function asyncio.run(loadtest_fn()) -``` \ No newline at end of file +``` + diff --git a/docs/my-website/docs/proxy/deploy.md b/docs/my-website/docs/proxy/deploy.md index 6de8625d0..4b51f094c 100644 --- a/docs/my-website/docs/proxy/deploy.md +++ b/docs/my-website/docs/proxy/deploy.md @@ -350,17 +350,3 @@ Run the command `docker-compose up` or `docker compose up` as per your docker in Your LiteLLM container should be running now on the defined port e.g. `8000`. - - - -## LiteLLM Proxy Performance - -LiteLLM proxy has been load tested to handle 1500 req/s. - -### Throughput - 30% Increase -LiteLLM proxy + Load Balancer gives **30% increase** in throughput compared to Raw OpenAI API - - -### Latency Added - 0.00325 seconds -LiteLLM proxy adds **0.00325 seconds** latency as compared to using the Raw OpenAI API - diff --git a/docs/my-website/img/locust.png b/docs/my-website/img/locust.png new file mode 100644 index 0000000000000000000000000000000000000000..1bcedf1d04b7b4debe3824113e4ea724f9bd4f8b GIT binary patch literal 111279 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�ex$cH^=p?6($O}b>Hb~GD_q05pzC;rZGrHAEZ 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 v{+g6rw`siVYK%vB3T$}N*+GN4OBWBm3)v8H literal 0 HcmV?d00001 From 9ed51e791b2c82ffda88767bc64a0f856f37c572 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 15:24:08 -0800 Subject: [PATCH 35/74] (fix) default num workers --- litellm/proxy/proxy_cli.py | 9 +++- .../proxy_load_test/litellm_proxy_config.yaml | 6 +++ litellm/proxy/proxy_load_test/locustfile.py | 27 ++++++++++ .../proxy/proxy_load_test/openai_endpoint.py | 50 +++++++++++++++++++ 4 files changed, 91 insertions(+), 1 deletion(-) create mode 100644 litellm/proxy/proxy_load_test/litellm_proxy_config.yaml create mode 100644 litellm/proxy/proxy_load_test/locustfile.py create mode 100644 litellm/proxy/proxy_load_test/openai_endpoint.py diff --git a/litellm/proxy/proxy_cli.py b/litellm/proxy/proxy_cli.py index f7eba02ec..367bbbb70 100644 --- a/litellm/proxy/proxy_cli.py +++ b/litellm/proxy/proxy_cli.py @@ -16,6 +16,13 @@ from importlib import resources import shutil telemetry = None +default_num_workers = 1 +try: + default_num_workers = os.cpu_count() or 1 + if default_num_workers is not None and default_num_workers > 0: + default_num_workers -= 1 +except: + pass def append_query_params(url, params): @@ -57,7 +64,7 @@ def is_port_in_use(port): @click.option("--port", default=8000, help="Port to bind the server to.", envvar="PORT") @click.option( "--num_workers", - default=1, + default=default_num_workers, help="Number of gunicorn workers to spin up", envvar="NUM_WORKERS", ) diff --git a/litellm/proxy/proxy_load_test/litellm_proxy_config.yaml b/litellm/proxy/proxy_load_test/litellm_proxy_config.yaml new file mode 100644 index 000000000..2e107d366 --- /dev/null +++ b/litellm/proxy/proxy_load_test/litellm_proxy_config.yaml @@ -0,0 +1,6 @@ +model_list: + - model_name: gpt-3.5-turbo + litellm_params: + model: openai/my-fake-model + api_key: my-fake-key + api_base: http://0.0.0.0:8090 \ No newline at end of file diff --git a/litellm/proxy/proxy_load_test/locustfile.py b/litellm/proxy/proxy_load_test/locustfile.py new file mode 100644 index 000000000..2cd2e2fcc --- /dev/null +++ b/litellm/proxy/proxy_load_test/locustfile.py @@ -0,0 +1,27 @@ +from locust import HttpUser, task, between + + +class MyUser(HttpUser): + wait_time = between(1, 5) + + @task + def chat_completion(self): + headers = { + "Content-Type": "application/json", + # Include any additional headers you may need for authentication, etc. + } + + # Customize the payload with "model" and "messages" keys + payload = { + "model": "gpt-3.5-turbo", + "messages": [ + {"role": "system", "content": "You are a chat bot."}, + {"role": "user", "content": "Hello, how are you?"}, + ], + # Add more data as necessary + } + + # Make a POST request to the "chat/completions" endpoint + response = self.client.post("chat/completions", json=payload, headers=headers) + + # Print or log the response if needed diff --git a/litellm/proxy/proxy_load_test/openai_endpoint.py b/litellm/proxy/proxy_load_test/openai_endpoint.py new file mode 100644 index 000000000..b3291ce70 --- /dev/null +++ b/litellm/proxy/proxy_load_test/openai_endpoint.py @@ -0,0 +1,50 @@ +# import sys, os +# sys.path.insert( +# 0, os.path.abspath("../") +# ) # Adds the parent directory to the system path +from fastapi import FastAPI, Request, status, HTTPException, Depends +from fastapi.responses import StreamingResponse +from fastapi.security import OAuth2PasswordBearer +from fastapi.middleware.cors import CORSMiddleware + +app = FastAPI() + +app.add_middleware( + CORSMiddleware, + allow_origins=["*"], + allow_credentials=True, + allow_methods=["*"], + allow_headers=["*"], +) + + +# for completion +@app.post("/chat/completions") +@app.post("/v1/chat/completions") +async def completion(request: Request): + return { + "id": "chatcmpl-123", + "object": "chat.completion", + "created": 1677652288, + "model": "gpt-3.5-turbo-0125", + "system_fingerprint": "fp_44709d6fcb", + "choices": [ + { + "index": 0, + "message": { + "role": "assistant", + "content": "\n\nHello there, how may I assist you today?", + }, + "logprobs": None, + "finish_reason": "stop", + } + ], + "usage": {"prompt_tokens": 9, "completion_tokens": 12, "total_tokens": 21}, + } + + +if __name__ == "__main__": + import uvicorn + + # run this on 8090, 8091, 8092 and 8093 + uvicorn.run(app, host="0.0.0.0", port=8090) From 986a5267907b4263db6af8c86b462aff2808cdd8 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 16:25:54 -0800 Subject: [PATCH 36/74] (feat) disable logging per request --- litellm/main.py | 2 ++ litellm/utils.py | 15 +++++++++------ 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/litellm/main.py b/litellm/main.py index 63649844a..76742eb06 100644 --- a/litellm/main.py +++ b/litellm/main.py @@ -563,6 +563,7 @@ def completion( "caching_groups", "ttl", "cache", + "no-log", ] default_params = openai_params + litellm_params non_default_params = { @@ -2417,6 +2418,7 @@ def embedding( "caching_groups", "ttl", "cache", + "no-log", ] default_params = openai_params + litellm_params non_default_params = { diff --git a/litellm/utils.py b/litellm/utils.py index 38836a4bc..01fab699a 100644 --- a/litellm/utils.py +++ b/litellm/utils.py @@ -2985,12 +2985,15 @@ def client(original_function): print_verbose( f"Async Wrapper: Completed Call, calling async_success_handler: {logging_obj.async_success_handler}" ) - asyncio.create_task( - logging_obj.async_success_handler(result, start_time, end_time) - ) - threading.Thread( - target=logging_obj.success_handler, args=(result, start_time, end_time) - ).start() + # check if user does not want this to be logged + if kwargs.get("no-log", False) == False: + asyncio.create_task( + logging_obj.async_success_handler(result, start_time, end_time) + ) + threading.Thread( + target=logging_obj.success_handler, + args=(result, start_time, end_time), + ).start() # RETURN RESULT if hasattr(result, "_hidden_params"): From 4ff68c85623d4c3a52cde986a69d9f29ee0c4ab5 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 16:26:25 -0800 Subject: [PATCH 37/74] (docs) no log requests --- docs/my-website/docs/proxy/enterprise.md | 51 +++++++++++++++++++----- 1 file changed, 40 insertions(+), 11 deletions(-) diff --git a/docs/my-website/docs/proxy/enterprise.md b/docs/my-website/docs/proxy/enterprise.md index a4f3ea7b1..e0c5374f0 100644 --- a/docs/my-website/docs/proxy/enterprise.md +++ b/docs/my-website/docs/proxy/enterprise.md @@ -12,14 +12,16 @@ Features here are behind a commercial license in our `/enterprise` folder. [**Se ::: Features: -- [ ] Content Moderation with LlamaGuard -- [ ] Content Moderation with Google Text Moderations -- [ ] Content Moderation with LLM Guard -- [ ] Reject calls from Blocked User list -- [ ] Reject calls (incoming / outgoing) with Banned Keywords (e.g. competitors) -- [ ] Tracking Spend for Custom Tags +- ✅ Content Moderation with LlamaGuard +- ✅ Content Moderation with Google Text Moderations +- ✅ Content Moderation with LLM Guard +- ✅ Reject calls from Blocked User list +- ✅ Reject calls (incoming / outgoing) with Banned Keywords (e.g. competitors) +- ✅ Don't log/store specific requests (eg confidential LLM requests) +- ✅ Tracking Spend for Custom Tags -## Content Moderation with LlamaGuard +## Content Moderation +### Content Moderation with LlamaGuard Currently works with Sagemaker's LlamaGuard endpoint. @@ -39,7 +41,7 @@ os.environ["AWS_SECRET_ACCESS_KEY"] = "" os.environ["AWS_REGION_NAME"] = "" ``` -### Customize LlamaGuard prompt +#### Customize LlamaGuard prompt To modify the unsafe categories llama guard evaluates against, just create your own version of [this category list](https://github.com/BerriAI/litellm/blob/main/litellm/proxy/llamaguard_prompt.txt) @@ -51,7 +53,7 @@ callbacks: ["llamaguard_moderations"] llamaguard_unsafe_content_categories: /path/to/llamaguard_prompt.txt ``` -## Content Moderation with LLM Guard +### Content Moderation with LLM Guard Set the LLM Guard API Base in your environment @@ -78,7 +80,7 @@ Expected results: LLM Guard: Received response - {"sanitized_prompt": "hello world", "is_valid": true, "scanners": { "Regex": 0.0 }} ``` -## Content Moderation with Google Text Moderation +### Content Moderation with Google Text Moderation Requires your GOOGLE_APPLICATION_CREDENTIALS to be set in your .env (same as VertexAI). @@ -89,7 +91,7 @@ litellm_settings: callbacks: ["google_text_moderation"] ``` -### Set custom confidence thresholds +#### Set custom confidence thresholds Google Moderations checks the test against several categories. [Source](https://cloud.google.com/natural-language/docs/moderating-text#safety_attribute_confidence_scores) @@ -133,6 +135,33 @@ Here are the category specific values: | "legal" | legal_threshold: 0.1 | +## Incognito Requests - Don't log anything + +When `no-log=True`, the request will **not be logged on any callbacks** and there will be **no server logs on litellm** + +```python +import openai +client = openai.OpenAI( + api_key="anything", # proxy api-key + base_url="http://0.0.0.0:8000" # litellm proxy +) + +response = client.chat.completions.create( + model="gpt-3.5-turbo", + messages = [ + { + "role": "user", + "content": "this is a test request, write a short poem" + } + ], + extra_body={ + "no-log": True + } +) + +print(response) +``` + ## Enable Blocked User Lists If any call is made to proxy with this user id, it'll be rejected - use this if you want to let users opt-out of ai features From d6dc28f0ed2d11329d23370071fef7f903e5f599 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 16:27:53 -0800 Subject: [PATCH 38/74] (fix) proxy setting success callbacks --- litellm/proxy/proxy_config.yaml | 9 +++------ litellm/proxy/proxy_server.py | 4 ++-- 2 files changed, 5 insertions(+), 8 deletions(-) diff --git a/litellm/proxy/proxy_config.yaml b/litellm/proxy/proxy_config.yaml index 654a50b2f..76c9ed04c 100644 --- a/litellm/proxy/proxy_config.yaml +++ b/litellm/proxy/proxy_config.yaml @@ -5,12 +5,9 @@ model_list: api_base: os.environ/AZURE_API_BASE api_key: os.environ/AZURE_API_KEY api_version: "2023-07-01-preview" - - model_name: azure-gpt-3.5 - litellm_params: - model: gpt-3.5-turbo - api_key: os.environ/OPENAI_API_KEY - model_info: - access_groups: ["public"] +litellm_settings: + set_verbose: True + success_callback: ["langfuse"] router_settings: set_verbose: True debug_level: "DEBUG" \ No newline at end of file diff --git a/litellm/proxy/proxy_server.py b/litellm/proxy/proxy_server.py index 19ac5c961..810fdc0d1 100644 --- a/litellm/proxy/proxy_server.py +++ b/litellm/proxy/proxy_server.py @@ -1675,9 +1675,9 @@ class ProxyConfig: # these are litellm callbacks - "langfuse", "sentry", "wandb" else: litellm.success_callback.append(callback) - verbose_proxy_logger.debug( + print( # noqa f"{blue_color_code} Initialized Success Callbacks - {litellm.success_callback} {reset_color_code}" - ) + ) # noqa elif key == "failure_callback": litellm.failure_callback = [] From ddd231a8c23557131a099f5ea26f7b1ba5f7a4a4 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 16:46:38 -0800 Subject: [PATCH 39/74] (feat) use no-log as a litellm param --- litellm/main.py | 3 +++ litellm/utils.py | 24 ++++++++++++++++-------- 2 files changed, 19 insertions(+), 8 deletions(-) diff --git a/litellm/main.py b/litellm/main.py index 76742eb06..c8a8dbc1c 100644 --- a/litellm/main.py +++ b/litellm/main.py @@ -487,6 +487,8 @@ def completion( ### ASYNC CALLS ### acompletion = kwargs.get("acompletion", False) client = kwargs.get("client", None) + ### Admin Controls ### + no_log = kwargs.get("no-log", False) ######## end of unpacking kwargs ########### openai_params = [ "functions", @@ -727,6 +729,7 @@ def completion( model_info=model_info, proxy_server_request=proxy_server_request, preset_cache_key=preset_cache_key, + no_log=no_log, ) logging.update_environment_variables( model=model, diff --git a/litellm/utils.py b/litellm/utils.py index 01fab699a..163223ab2 100644 --- a/litellm/utils.py +++ b/litellm/utils.py @@ -1279,6 +1279,10 @@ class Logging: for callback in callbacks: try: + litellm_params = self.model_call_details.get("litellm_params", {}) + if litellm_params.get("no-log", False) == True: + print_verbose("no-log request, skipping logging") + continue if callback == "lite_debugger": print_verbose("reaches lite_debugger for logging!") print_verbose(f"liteDebuggerClient: {liteDebuggerClient}") @@ -1708,6 +1712,9 @@ class Logging: verbose_logger.debug(f"Async success callbacks: {callbacks}") for callback in callbacks: try: + if kwargs.get("no-log", False) == True: + print_verbose("no-log request, skipping logging") + continue if callback == "cache" and litellm.cache is not None: # set_cache once complete streaming response is built print_verbose("async success_callback: reaches cache for logging!") @@ -2986,14 +2993,13 @@ def client(original_function): f"Async Wrapper: Completed Call, calling async_success_handler: {logging_obj.async_success_handler}" ) # check if user does not want this to be logged - if kwargs.get("no-log", False) == False: - asyncio.create_task( - logging_obj.async_success_handler(result, start_time, end_time) - ) - threading.Thread( - target=logging_obj.success_handler, - args=(result, start_time, end_time), - ).start() + asyncio.create_task( + logging_obj.async_success_handler(result, start_time, end_time) + ) + threading.Thread( + target=logging_obj.success_handler, + args=(result, start_time, end_time), + ).start() # RETURN RESULT if hasattr(result, "_hidden_params"): @@ -3895,6 +3901,7 @@ def get_litellm_params( proxy_server_request=None, acompletion=None, preset_cache_key=None, + no_log=None, ): litellm_params = { "acompletion": acompletion, @@ -3911,6 +3918,7 @@ def get_litellm_params( "model_info": model_info, "proxy_server_request": proxy_server_request, "preset_cache_key": preset_cache_key, + "no-log": no_log, "stream_response": {}, # litellm_call_id: ModelResponse Dict } From 0a538fe679a066608bbf997d5d96d646f52adb90 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 16:56:20 -0800 Subject: [PATCH 40/74] (feat) use no-log to disable per request logging --- litellm/utils.py | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/litellm/utils.py b/litellm/utils.py index 163223ab2..32f0f765b 100644 --- a/litellm/utils.py +++ b/litellm/utils.py @@ -1281,8 +1281,13 @@ class Logging: try: litellm_params = self.model_call_details.get("litellm_params", {}) if litellm_params.get("no-log", False) == True: - print_verbose("no-log request, skipping logging") - continue + # proxy cost tracking cal backs should run + if not ( + isinstance(callback, CustomLogger) + and "_PROXY_" in callback.__class__.__name__ + ): + print_verbose("no-log request, skipping logging") + continue if callback == "lite_debugger": print_verbose("reaches lite_debugger for logging!") print_verbose(f"liteDebuggerClient: {liteDebuggerClient}") @@ -1711,6 +1716,16 @@ class Logging: callbacks = litellm._async_success_callback verbose_logger.debug(f"Async success callbacks: {callbacks}") for callback in callbacks: + # check if callback can run for this request + litellm_params = self.model_call_details.get("litellm_params", {}) + if litellm_params.get("no-log", False) == True: + # proxy cost tracking cal backs should run + if not ( + isinstance(callback, CustomLogger) + and "_PROXY_" in callback.__class__.__name__ + ): + print_verbose("no-log request, skipping logging") + continue try: if kwargs.get("no-log", False) == True: print_verbose("no-log request, skipping logging") From 37b4dde7fd3ade2eae5a5f5c6dcc11fed5e0d1a3 Mon Sep 17 00:00:00 2001 From: Guillermo Date: Sat, 9 Mar 2024 02:24:07 +0100 Subject: [PATCH 41/74] Add quickstart deploy with k8s --- docs/my-website/docs/proxy/deploy.md | 64 ++++++++++++++++++++++++++++ 1 file changed, 64 insertions(+) diff --git a/docs/my-website/docs/proxy/deploy.md b/docs/my-website/docs/proxy/deploy.md index 4b51f094c..b2e48d522 100644 --- a/docs/my-website/docs/proxy/deploy.md +++ b/docs/my-website/docs/proxy/deploy.md @@ -68,6 +68,70 @@ CMD ["--port", "4000", "--config", "config.yaml", "--detailed_debug", "--run_gun + + +Deploying a config file based litellm instance, just requires a simple deployment that loads +the config.yaml file via a config map. + +```yaml +apiVersion: v1 +kind: ConfigMap +metadata: + name: litellm-config-file +data: + config.yaml: | + model_list: + - model_name: gpt-3.5-turbo # user-facing model alias + litellm_params: # all params accepted by litellm.completion() - https://docs.litellm.ai/docs/completion/input + model: azure/ + api_base: + api_key: + - model_name: gpt-3.5-turbo + litellm_params: + model: azure/gpt-turbo-small-ca + api_base: https://my-endpoint-canada-berri992.openai.azure.com/ + api_key: + - model_name: vllm-model + litellm_params: + model: openai/ + api_base: # e.g. http://0.0.0.0:3000 +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: litellm-deployment + labels: + app: litellm +spec: + selector: + matchLabels: + app: litellm + template: + metadata: + labels: + app: litellm + spec: + containers: + - name: litellm + image: ghcr.io/berriai/litellm:main-latest # it is recommended to fix a version generally + ports: + - containerPort: 4000 + volumeMounts: + - name: config-volume + mountPath: /app/proxy_server_config.yaml + subPath: config.yaml + envFrom: + - secretRef: + name: litellm-secrets + volumes: + - name: config-volume + configMap: + name: litellm-config-file + +``` + + + ## Deploy with Database From bb427b465982905a54c4a5b836ae9aab93cdbe8f Mon Sep 17 00:00:00 2001 From: Guillermo Date: Sat, 9 Mar 2024 02:30:17 +0100 Subject: [PATCH 42/74] Update deploy.md --- docs/my-website/docs/proxy/deploy.md | 25 ++++++++++++------------- 1 file changed, 12 insertions(+), 13 deletions(-) diff --git a/docs/my-website/docs/proxy/deploy.md b/docs/my-website/docs/proxy/deploy.md index b2e48d522..0ce9c0005 100644 --- a/docs/my-website/docs/proxy/deploy.md +++ b/docs/my-website/docs/proxy/deploy.md @@ -70,8 +70,9 @@ CMD ["--port", "4000", "--config", "config.yaml", "--detailed_debug", "--run_gun -Deploying a config file based litellm instance, just requires a simple deployment that loads -the config.yaml file via a config map. +Deploying a config file based litellm instance just requires a simple deployment that loads +the config.yaml file via a config map. Also it would be a good practice to use the env var +declaration for api keys, and attach the env vars with the api key values as an opaque secret. ```yaml apiVersion: v1 @@ -81,20 +82,19 @@ metadata: data: config.yaml: | model_list: - - model_name: gpt-3.5-turbo # user-facing model alias - litellm_params: # all params accepted by litellm.completion() - https://docs.litellm.ai/docs/completion/input - model: azure/ - api_base: - api_key: - model_name: gpt-3.5-turbo litellm_params: model: azure/gpt-turbo-small-ca api_base: https://my-endpoint-canada-berri992.openai.azure.com/ - api_key: - - model_name: vllm-model - litellm_params: - model: openai/ - api_base: # e.g. http://0.0.0.0:3000 + api_key: os.environ/CA_AZURE_OPENAI_API_KEY +--- +apiVersion: v1 +kind: Secret +type: Opaque +metadata: + name: litellm-secrets +data: + CA_AZURE_OPENAI_API_KEY: bWVvd19pbV9hX2NhdA== # your api key in base64 --- apiVersion: apps/v1 kind: Deployment @@ -127,7 +127,6 @@ spec: - name: config-volume configMap: name: litellm-config-file - ``` From 0fb7afe8202c65e277e962cc0571207cad357e67 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 18:20:27 -0800 Subject: [PATCH 43/74] feat(proxy_server.py): working `/audio/transcription` endpoint --- litellm/llms/azure.py | 27 +++++++--- litellm/llms/openai.py | 4 +- litellm/main.py | 7 +-- litellm/proxy/proxy_server.py | 95 +++++++++++++++++++++-------------- litellm/utils.py | 14 ++++-- tests/test_whisper.py | 2 +- 6 files changed, 95 insertions(+), 54 deletions(-) diff --git a/litellm/llms/azure.py b/litellm/llms/azure.py index e19023b03..022266996 100644 --- a/litellm/llms/azure.py +++ b/litellm/llms/azure.py @@ -770,9 +770,8 @@ class AzureChatCompletion(BaseLLM): api_version: Optional[str] = None, client=None, azure_ad_token: Optional[str] = None, - max_retries=None, logging_obj=None, - atranscriptions: bool = False, + atranscription: bool = False, ): data = {"model": model, "file": audio_file, **optional_params} @@ -781,9 +780,11 @@ class AzureChatCompletion(BaseLLM): "api_version": api_version, "azure_endpoint": api_base, "azure_deployment": model, - "max_retries": max_retries, "timeout": timeout, } + + max_retries = optional_params.pop("max_retries", None) + azure_client_params = select_azure_base_url_or_endpoint( azure_client_params=azure_client_params ) @@ -792,7 +793,10 @@ class AzureChatCompletion(BaseLLM): elif azure_ad_token is not None: azure_client_params["azure_ad_token"] = azure_ad_token - if atranscriptions == True: + if max_retries is not None: + azure_client_params["max_retries"] = max_retries + + if atranscription == True: return self.async_audio_transcriptions( audio_file=audio_file, data=data, @@ -845,18 +849,29 @@ class AzureChatCompletion(BaseLLM): ) else: async_azure_client = client + response = await async_azure_client.audio.transcriptions.create( **data, timeout=timeout ) # type: ignore + stringified_response = response.model_dump() + ## LOGGING logging_obj.post_call( input=audio_file.name, api_key=api_key, - additional_args={"complete_input_dict": data}, + additional_args={ + "headers": { + "Authorization": f"Bearer {async_azure_client.api_key}" + }, + "api_base": async_azure_client._base_url._uri_reference, + "atranscription": True, + "complete_input_dict": data, + }, original_response=stringified_response, ) - return convert_to_model_response_object(response_object=stringified_response, model_response_object=model_response, response_type="image_generation") # type: ignore + response = convert_to_model_response_object(response_object=stringified_response, model_response_object=model_response, response_type="audio_transcription") # type: ignore + return response except Exception as e: ## LOGGING logging_obj.post_call( diff --git a/litellm/llms/openai.py b/litellm/llms/openai.py index fca950d31..a90d2457a 100644 --- a/litellm/llms/openai.py +++ b/litellm/llms/openai.py @@ -779,10 +779,10 @@ class OpenAIChatCompletion(BaseLLM): client=None, max_retries=None, logging_obj=None, - atranscriptions: bool = False, + atranscription: bool = False, ): data = {"model": model, "file": audio_file, **optional_params} - if atranscriptions == True: + if atranscription == True: return self.async_audio_transcriptions( audio_file=audio_file, data=data, diff --git a/litellm/main.py b/litellm/main.py index a04dba4ec..6deaf653f 100644 --- a/litellm/main.py +++ b/litellm/main.py @@ -3385,7 +3385,7 @@ def transcription( Allows router to load balance between them """ - atranscriptions = kwargs.get("atranscriptions", False) + atranscription = kwargs.get("atranscription", False) litellm_call_id = kwargs.get("litellm_call_id", None) logger_fn = kwargs.get("logger_fn", None) proxy_server_request = kwargs.get("proxy_server_request", None) @@ -3421,12 +3421,13 @@ def transcription( or litellm.azure_key or get_secret("AZURE_API_KEY") ) + response = azure_chat_completions.audio_transcriptions( model=model, audio_file=file, optional_params=optional_params, model_response=model_response, - atranscriptions=atranscriptions, + atranscription=atranscription, timeout=timeout, logging_obj=litellm_logging_obj, api_base=api_base, @@ -3440,7 +3441,7 @@ def transcription( audio_file=file, optional_params=optional_params, model_response=model_response, - atranscriptions=atranscriptions, + atranscription=atranscription, timeout=timeout, logging_obj=litellm_logging_obj, ) diff --git a/litellm/proxy/proxy_server.py b/litellm/proxy/proxy_server.py index 27eeea573..7a04c8e7d 100644 --- a/litellm/proxy/proxy_server.py +++ b/litellm/proxy/proxy_server.py @@ -120,6 +120,8 @@ from fastapi import ( Header, Response, Form, + UploadFile, + File, ) from fastapi.routing import APIRouter from fastapi.security import OAuth2PasswordBearer @@ -3216,17 +3218,16 @@ async def image_generation( @router.post( "/v1/audio/transcriptions", dependencies=[Depends(user_api_key_auth)], - response_class=ORJSONResponse, tags=["audio"], ) @router.post( "/audio/transcriptions", dependencies=[Depends(user_api_key_auth)], - response_class=ORJSONResponse, tags=["audio"], ) async def audio_transcriptions( request: Request, + file: UploadFile = File(...), user_api_key_dict: UserAPIKeyAuth = Depends(user_api_key_auth), ): """ @@ -3237,11 +3238,11 @@ async def audio_transcriptions( global proxy_logging_obj try: # Use orjson to parse JSON data, orjson speeds up requests significantly - body = await request.body() - data = orjson.loads(body) + form_data = await request.form() + data: Dict = {key: value for key, value in form_data.items() if key != "file"} # Include original request and headers in the data - data["proxy_server_request"] = { + data["proxy_server_request"] = { # type: ignore "url": str(request.url), "method": request.method, "headers": dict(request.headers), @@ -3298,44 +3299,60 @@ async def audio_transcriptions( else [] ) - ### CALL HOOKS ### - modify incoming data / reject request before calling the model - data = await proxy_logging_obj.pre_call_hook( - user_api_key_dict=user_api_key_dict, data=data, call_type="moderation" - ) + assert ( + file.filename is not None + ) # make sure filename passed in (needed for type) - start_time = time.time() + with open(file.filename, "wb+") as f: + f.write(await file.read()) + try: + data["file"] = open(file.filename, "rb") + ### CALL HOOKS ### - modify incoming data / reject request before calling the model + data = await proxy_logging_obj.pre_call_hook( + user_api_key_dict=user_api_key_dict, + data=data, + call_type="moderation", + ) - ## ROUTE TO CORRECT ENDPOINT ## - # skip router if user passed their key - if "api_key" in data: - response = await litellm.atranscription(**data) - elif ( - llm_router is not None and data["model"] in router_model_names - ): # model in router model list - response = await llm_router.atranscription(**data) - elif ( - llm_router is not None and data["model"] in llm_router.deployment_names - ): # model in router deployments, calling a specific deployment on the router - response = await llm_router.atranscription(**data, specific_deployment=True) - elif ( - llm_router is not None - and llm_router.model_group_alias is not None - and data["model"] in llm_router.model_group_alias - ): # model set in model_group_alias - response = await llm_router.atranscription( - **data - ) # ensure this goes the llm_router, router will do the correct alias mapping - elif user_model is not None: # `litellm --model ` - response = await litellm.atranscription(**data) - else: - raise HTTPException( - status_code=status.HTTP_400_BAD_REQUEST, - detail={"error": "Invalid model name passed in"}, - ) + ## ROUTE TO CORRECT ENDPOINT ## + # skip router if user passed their key + if "api_key" in data: + response = await litellm.atranscription(**data) + elif ( + llm_router is not None and data["model"] in router_model_names + ): # model in router model list + response = await llm_router.atranscription(**data) + + elif ( + llm_router is not None + and data["model"] in llm_router.deployment_names + ): # model in router deployments, calling a specific deployment on the router + response = await llm_router.atranscription( + **data, specific_deployment=True + ) + elif ( + llm_router is not None + and llm_router.model_group_alias is not None + and data["model"] in llm_router.model_group_alias + ): # model set in model_group_alias + response = await llm_router.atranscription( + **data + ) # ensure this goes the llm_router, router will do the correct alias mapping + elif user_model is not None: # `litellm --model ` + response = await litellm.atranscription(**data) + else: + raise HTTPException( + status_code=status.HTTP_400_BAD_REQUEST, + detail={"error": "Invalid model name passed in"}, + ) + + except Exception as e: + raise HTTPException(status_code=500, detail=str(e)) + finally: + os.remove(file.filename) # Delete the saved file ### ALERTING ### data["litellm_status"] = "success" # used for alerting - return response except Exception as e: await proxy_logging_obj.post_call_failure_hook( @@ -3344,7 +3361,7 @@ async def audio_transcriptions( traceback.print_exc() if isinstance(e, HTTPException): raise ProxyException( - message=getattr(e, "message", str(e)), + message=getattr(e, "message", str(e.detail)), type=getattr(e, "type", "None"), param=getattr(e, "param", "None"), code=getattr(e, "status_code", status.HTTP_400_BAD_REQUEST), diff --git a/litellm/utils.py b/litellm/utils.py index 330903f5a..3285f3a08 100644 --- a/litellm/utils.py +++ b/litellm/utils.py @@ -2309,7 +2309,7 @@ def client(original_function): or call_type == CallTypes.transcription.value ): _file_name: BinaryIO = args[1] if len(args) > 1 else kwargs["file"] - messages = _file_name.name + messages = "audio_file" stream = True if "stream" in kwargs and kwargs["stream"] == True else False logging_obj = Logging( model=model, @@ -2607,6 +2607,8 @@ def client(original_function): return result elif "aimg_generation" in kwargs and kwargs["aimg_generation"] == True: return result + elif "atranscription" in kwargs and kwargs["atranscription"] == True: + return result ### POST-CALL RULES ### post_call_processing(original_response=result, model=model or None) @@ -7834,7 +7836,9 @@ def exception_type( message=f"AzureException - {original_exception.message}", llm_provider="azure", model=model, - request=original_exception.request, + request=httpx.Request( + method="POST", url="https://openai.com/" + ), ) else: # if no status code then it is an APIConnectionError: https://github.com/openai/openai-python#handling-errors @@ -7842,7 +7846,11 @@ def exception_type( __cause__=original_exception.__cause__, llm_provider="azure", model=model, - request=original_exception.request, + request=getattr( + original_exception, + "request", + httpx.Request(method="POST", url="https://openai.com/"), + ), ) if ( "BadRequestError.__init__() missing 1 required positional argument: 'param'" diff --git a/tests/test_whisper.py b/tests/test_whisper.py index bb0971732..5cb651951 100644 --- a/tests/test_whisper.py +++ b/tests/test_whisper.py @@ -98,7 +98,7 @@ async def test_transcription_on_router(): "model": "azure/azure-whisper", "api_base": os.getenv("AZURE_EUROPE_API_BASE"), "api_key": os.getenv("AZURE_EUROPE_API_KEY"), - "api_version": os.getenv("2024-02-15-preview"), + "api_version": "2024-02-15-preview", }, }, ] From 5850ff470f589959cc4d23fe7b3275b649c81088 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 20:42:12 -0800 Subject: [PATCH 44/74] (feat) disable/enable logging --- litellm/_logging.py | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/litellm/_logging.py b/litellm/_logging.py index 438fa9743..26693c15e 100644 --- a/litellm/_logging.py +++ b/litellm/_logging.py @@ -31,6 +31,18 @@ def _turn_on_debug(): verbose_proxy_logger.setLevel(level=logging.DEBUG) # set proxy logs to debug +def _disable_debugging(): + verbose_logger.disabled = True + verbose_router_logger.disabled = True + verbose_proxy_logger.disabled = True + + +def _enable_debugging(): + verbose_logger.disabled = False + verbose_router_logger.disabled = False + verbose_proxy_logger.disabled = False + + def print_verbose(print_statement): try: if set_verbose: From 7004940ce4d890fca1c7cd360847103035def2bd Mon Sep 17 00:00:00 2001 From: H0llyW00dzZ Date: Sat, 9 Mar 2024 11:55:31 +0700 Subject: [PATCH 45/74] Update Docs for Kubernetes - [+] docs(deploy.md): add tip about using versioning or SHA digests instead of latest tag --- docs/my-website/docs/proxy/deploy.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/docs/my-website/docs/proxy/deploy.md b/docs/my-website/docs/proxy/deploy.md index 0ce9c0005..7eb5373b4 100644 --- a/docs/my-website/docs/proxy/deploy.md +++ b/docs/my-website/docs/proxy/deploy.md @@ -131,6 +131,9 @@ spec: +> [!TIP] +> To avoid issues with predictability, difficulties in rollback, and inconsistent environments, use versioning or SHA digests (for example, `litellm:main-v1.30.3` or `litellm@sha256:12345abcdef...`) instead of `litellm:main-latest`. + ## Deploy with Database From 789183013697dd171a6986c20c9253c70e7e0468 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 21:20:02 -0800 Subject: [PATCH 46/74] (bump) 1.30.4 --- pyproject.toml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 80f5c822c..4c00be910 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "litellm" -version = "1.30.3" +version = "1.30.4" description = "Library to easily interface with LLM API providers" authors = ["BerriAI"] license = "MIT" @@ -74,7 +74,7 @@ requires = ["poetry-core", "wheel"] build-backend = "poetry.core.masonry.api" [tool.commitizen] -version = "1.30.3" +version = "1.30.4" version_files = [ "pyproject.toml:^version" ] From 33ba57a1b51050e055a3ddecb186e33bcfb7e640 Mon Sep 17 00:00:00 2001 From: H0llyW00dzZ Date: Sat, 9 Mar 2024 12:37:18 +0700 Subject: [PATCH 47/74] Fix Docs Formatting in Website - [+] docs(deploy.md): move tip about versioning inside the tab item --- docs/my-website/docs/proxy/deploy.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/my-website/docs/proxy/deploy.md b/docs/my-website/docs/proxy/deploy.md index 7eb5373b4..496bde05f 100644 --- a/docs/my-website/docs/proxy/deploy.md +++ b/docs/my-website/docs/proxy/deploy.md @@ -129,11 +129,11 @@ spec: name: litellm-config-file ``` - - > [!TIP] > To avoid issues with predictability, difficulties in rollback, and inconsistent environments, use versioning or SHA digests (for example, `litellm:main-v1.30.3` or `litellm@sha256:12345abcdef...`) instead of `litellm:main-latest`. + + ## Deploy with Database From 2e66267128564d4670b43de43f5b5ce0db6ee6d5 Mon Sep 17 00:00:00 2001 From: Krish Dholakia Date: Fri, 8 Mar 2024 21:47:11 -0800 Subject: [PATCH 48/74] Updated config.yml --- .circleci/config.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.circleci/config.yml b/.circleci/config.yml index daa4d59ec..ff6e6e1b2 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -45,6 +45,7 @@ jobs: pip install "asyncio==3.4.3" pip install "apscheduler==3.10.4" pip install "PyGithub==1.59.1" + pip install python-multipart - save_cache: paths: - ./venv From ea6f42216c313d9b91794eb27a6b0699a1683164 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 21:59:00 -0800 Subject: [PATCH 49/74] (docs) use port 4000 --- README.md | 6 +-- deploy/charts/litellm/README.md | 4 +- deploy/charts/litellm/values.yaml | 2 +- .../docs/embedding/supported_embedding.md | 10 ++-- docs/my-website/docs/index.md | 4 +- docs/my-website/docs/load_test.md | 2 +- docs/my-website/docs/providers/anthropic.md | 8 +-- docs/my-website/docs/providers/bedrock.md | 8 +-- docs/my-website/docs/providers/ollama.md | 2 +- .../docs/providers/openai_compatible.md | 4 +- docs/my-website/docs/proxy/caching.md | 14 ++--- docs/my-website/docs/proxy/call_hooks.md | 4 +- docs/my-website/docs/proxy/cli.md | 2 +- docs/my-website/docs/proxy/configs.md | 16 +++--- docs/my-website/docs/proxy/deploy.md | 10 ++-- docs/my-website/docs/proxy/embedding.md | 2 +- docs/my-website/docs/proxy/enterprise.md | 18 +++---- docs/my-website/docs/proxy/health.md | 10 ++-- docs/my-website/docs/proxy/load_balancing.md | 4 +- docs/my-website/docs/proxy/logging.md | 24 ++++----- .../my-website/docs/proxy/model_management.md | 4 +- docs/my-website/docs/proxy/pii_masking.md | 6 +-- docs/my-website/docs/proxy/quick_start.md | 36 ++++++------- docs/my-website/docs/proxy/reliability.md | 6 +-- docs/my-website/docs/proxy/rules.md | 2 +- .../docs/proxy/streaming_logging.md | 2 +- docs/my-website/docs/proxy/ui.md | 4 +- docs/my-website/docs/proxy/user_keys.md | 30 +++++------ docs/my-website/docs/proxy/users.md | 26 +++++----- docs/my-website/docs/proxy/virtual_keys.md | 28 +++++----- docs/my-website/docs/simple_proxy_old_doc.md | 52 +++++++++---------- litellm/proxy/proxy_cli.py | 6 +-- litellm/router.py | 2 +- 33 files changed, 179 insertions(+), 179 deletions(-) diff --git a/README.md b/README.md index bc8c1bae2..d32372b6c 100644 --- a/README.md +++ b/README.md @@ -143,13 +143,13 @@ pip install 'litellm[proxy]' ```shell $ litellm --model huggingface/bigcode/starcoder -#INFO: Proxy running on http://0.0.0.0:8000 +#INFO: Proxy running on http://0.0.0.0:4000 ``` ### Step 2: Make ChatCompletions Request to Proxy ```python import openai # openai v1.0.0+ -client = openai.OpenAI(api_key="anything",base_url="http://0.0.0.0:8000") # set proxy to base_url +client = openai.OpenAI(api_key="anything",base_url="http://0.0.0.0:4000") # set proxy to base_url # request sent to model set on litellm proxy, `litellm --model` response = client.chat.completions.create(model="gpt-3.5-turbo", messages = [ { @@ -170,7 +170,7 @@ Set budgets and rate limits across multiple projects ### Request ```shell -curl 'http://0.0.0.0:8000/key/generate' \ +curl 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer sk-1234' \ --header 'Content-Type: application/json' \ --data-raw '{"models": ["gpt-3.5-turbo", "gpt-4", "claude-2"], "duration": "20m","metadata": {"user": "ishaan@berri.ai", "team": "core-infra"}}' diff --git a/deploy/charts/litellm/README.md b/deploy/charts/litellm/README.md index daba8aa68..817781ed0 100644 --- a/deploy/charts/litellm/README.md +++ b/deploy/charts/litellm/README.md @@ -28,7 +28,7 @@ If `db.useStackgresOperator` is used (not yet implemented): | `imagePullSecrets` | Registry credentials for the LiteLLM and initContainer images. | `[]` | | `serviceAccount.create` | Whether or not to create a Kubernetes Service Account for this deployment. The default is `false` because LiteLLM has no need to access the Kubernetes API. | `false` | | `service.type` | Kubernetes Service type (e.g. `LoadBalancer`, `ClusterIP`, etc.) | `ClusterIP` | -| `service.port` | TCP port that the Kubernetes Service will listen on. Also the TCP port within the Pod that the proxy will listen on. | `8000` | +| `service.port` | TCP port that the Kubernetes Service will listen on. Also the TCP port within the Pod that the proxy will listen on. | `4000` | | `ingress.*` | See [values.yaml](./values.yaml) for example settings | N/A | | `proxy_config.*` | See [values.yaml](./values.yaml) for default settings. See [example_config_yaml](../../../litellm/proxy/example_config_yaml/) for configuration examples. | N/A | @@ -76,7 +76,7 @@ When browsing to the URL published per the settings in `ingress.*`, you will be prompted for **Admin Configuration**. The **Proxy Endpoint** is the internal (from the `litellm` pod's perspective) URL published by the `-litellm` Kubernetes Service. If the deployment uses the default settings for this -service, the **Proxy Endpoint** should be set to `http://-litellm:8000`. +service, the **Proxy Endpoint** should be set to `http://-litellm:4000`. The **Proxy Key** is the value specified for `masterkey` or, if a `masterkey` was not provided to the helm command line, the `masterkey` is a randomly diff --git a/deploy/charts/litellm/values.yaml b/deploy/charts/litellm/values.yaml index 1b83fe801..642a50b70 100644 --- a/deploy/charts/litellm/values.yaml +++ b/deploy/charts/litellm/values.yaml @@ -55,7 +55,7 @@ environmentSecrets: [] service: type: ClusterIP - port: 8000 + port: 4000 ingress: enabled: false diff --git a/docs/my-website/docs/embedding/supported_embedding.md b/docs/my-website/docs/embedding/supported_embedding.md index 62a10b44d..7e2374d16 100644 --- a/docs/my-website/docs/embedding/supported_embedding.md +++ b/docs/my-website/docs/embedding/supported_embedding.md @@ -35,7 +35,7 @@ general_settings: ```bash litellm --config /path/to/config.yaml -# RUNNING on http://0.0.0.0:8000 +# RUNNING on http://0.0.0.0:4000 ``` ### Test @@ -44,7 +44,7 @@ litellm --config /path/to/config.yaml ```bash -curl --location 'http://0.0.0.0:8000/embeddings' \ +curl --location 'http://0.0.0.0:4000/embeddings' \ --header 'Authorization: Bearer sk-1234' \ --header 'Content-Type: application/json' \ --data '{"input": ["Academia.edu uses"], "model": "textembedding-gecko", "encoding_format": "base64"}' @@ -57,7 +57,7 @@ curl --location 'http://0.0.0.0:8000/embeddings' \ from openai import OpenAI client = OpenAI( api_key="sk-1234", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) client.embeddings.create( @@ -72,7 +72,7 @@ client.embeddings.create( ```python from langchain_openai import OpenAIEmbeddings -embeddings = OpenAIEmbeddings(model="textembedding-gecko", openai_api_base="http://0.0.0.0:8000", openai_api_key="sk-1234") +embeddings = OpenAIEmbeddings(model="textembedding-gecko", openai_api_base="http://0.0.0.0:4000", openai_api_key="sk-1234") text = "This is a test document." @@ -200,7 +200,7 @@ Use this for calling `/embedding` endpoints on OpenAI Compatible Servers, exampl from litellm import embedding response = embedding( model = "openai/", # add `openai/` prefix to model so litellm knows to route to OpenAI - api_base="http://0.0.0.0:8000/" # set API Base of your Custom OpenAI Endpoint + api_base="http://0.0.0.0:4000/" # set API Base of your Custom OpenAI Endpoint input=["good morning from litellm"] ) ``` diff --git a/docs/my-website/docs/index.md b/docs/my-website/docs/index.md index d7ed14019..66ec6573c 100644 --- a/docs/my-website/docs/index.md +++ b/docs/my-website/docs/index.md @@ -368,13 +368,13 @@ pip install 'litellm[proxy]' ```shell $ litellm --model huggingface/bigcode/starcoder -#INFO: Proxy running on http://0.0.0.0:8000 +#INFO: Proxy running on http://0.0.0.0:4000 ``` #### Step 2: Make ChatCompletions Request to Proxy ```python import openai # openai v1.0.0+ -client = openai.OpenAI(api_key="anything",base_url="http://0.0.0.0:8000") # set proxy to base_url +client = openai.OpenAI(api_key="anything",base_url="http://0.0.0.0:4000") # set proxy to base_url # request sent to model set on litellm proxy, `litellm --model` response = client.chat.completions.create(model="gpt-3.5-turbo", messages = [ { diff --git a/docs/my-website/docs/load_test.md b/docs/my-website/docs/load_test.md index 94165fb7b..f85ff9122 100644 --- a/docs/my-website/docs/load_test.md +++ b/docs/my-website/docs/load_test.md @@ -90,7 +90,7 @@ import time, asyncio, litellm #### LITELLM PROXY #### litellm_client = AsyncOpenAI( api_key="sk-1234", # [CHANGE THIS] - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) #### AZURE OPENAI CLIENT #### diff --git a/docs/my-website/docs/providers/anthropic.md b/docs/my-website/docs/providers/anthropic.md index 6aa4b1979..1a7a5fa41 100644 --- a/docs/my-website/docs/providers/anthropic.md +++ b/docs/my-website/docs/providers/anthropic.md @@ -63,7 +63,7 @@ export ANTHROPIC_API_KEY="your-api-key" ```bash $ litellm --model claude-3-opus-20240229 -# Server running on http://0.0.0.0:8000 +# Server running on http://0.0.0.0:4000 ``` ### 3. Test it @@ -73,7 +73,7 @@ $ litellm --model claude-3-opus-20240229 ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "gpt-3.5-turbo", @@ -93,7 +93,7 @@ curl --location 'http://0.0.0.0:8000/chat/completions' \ import openai client = openai.OpenAI( api_key="anything", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # request sent to model set on litellm proxy, `litellm --model` @@ -120,7 +120,7 @@ from langchain.prompts.chat import ( from langchain.schema import HumanMessage, SystemMessage chat = ChatOpenAI( - openai_api_base="http://0.0.0.0:8000", # set openai_api_base to the LiteLLM Proxy + openai_api_base="http://0.0.0.0:4000", # set openai_api_base to the LiteLLM Proxy model = "gpt-3.5-turbo", temperature=0.1 ) diff --git a/docs/my-website/docs/providers/bedrock.md b/docs/my-website/docs/providers/bedrock.md index c5b12d4c4..8c6926885 100644 --- a/docs/my-website/docs/providers/bedrock.md +++ b/docs/my-website/docs/providers/bedrock.md @@ -54,7 +54,7 @@ export AWS_REGION_NAME="" ```bash $ litellm --model anthropic.claude-3-sonnet-20240229-v1:0 -# Server running on http://0.0.0.0:8000 +# Server running on http://0.0.0.0:4000 ``` ### 3. Test it @@ -64,7 +64,7 @@ $ litellm --model anthropic.claude-3-sonnet-20240229-v1:0 ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "gpt-3.5-turbo", @@ -84,7 +84,7 @@ curl --location 'http://0.0.0.0:8000/chat/completions' \ import openai client = openai.OpenAI( api_key="anything", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # request sent to model set on litellm proxy, `litellm --model` @@ -111,7 +111,7 @@ from langchain.prompts.chat import ( from langchain.schema import HumanMessage, SystemMessage chat = ChatOpenAI( - openai_api_base="http://0.0.0.0:8000", # set openai_api_base to the LiteLLM Proxy + openai_api_base="http://0.0.0.0:4000", # set openai_api_base to the LiteLLM Proxy model = "gpt-3.5-turbo", temperature=0.1 ) diff --git a/docs/my-website/docs/providers/ollama.md b/docs/my-website/docs/providers/ollama.md index 78c91bb63..ec2a231e1 100644 --- a/docs/my-website/docs/providers/ollama.md +++ b/docs/my-website/docs/providers/ollama.md @@ -183,7 +183,7 @@ On the docker container run the `test.py` file using `python3 test.py` ```python import openai -api_base = f"http://0.0.0.0:8000" # base url for server +api_base = f"http://0.0.0.0:4000" # base url for server openai.api_base = api_base openai.api_key = "temp-key" diff --git a/docs/my-website/docs/providers/openai_compatible.md b/docs/my-website/docs/providers/openai_compatible.md index beaf38cfa..f86544c28 100644 --- a/docs/my-website/docs/providers/openai_compatible.md +++ b/docs/my-website/docs/providers/openai_compatible.md @@ -15,7 +15,7 @@ import os response = litellm.completion( model="openai/mistral, # add `openai/` prefix to model so litellm knows to route to OpenAI api_key="sk-1234", # api key to your openai compatible endpoint - api_base="http://0.0.0.0:8000", # set API Base of your Custom OpenAI Endpoint + api_base="http://0.0.0.0:4000", # set API Base of your Custom OpenAI Endpoint messages=[ { "role": "user", @@ -35,7 +35,7 @@ import os response = litellm.embedding( model="openai/GPT-J", # add `openai/` prefix to model so litellm knows to route to OpenAI api_key="sk-1234", # api key to your openai compatible endpoint - api_base="http://0.0.0.0:8000", # set API Base of your Custom OpenAI Endpoint + api_base="http://0.0.0.0:4000", # set API Base of your Custom OpenAI Endpoint input=["good morning from litellm"] ) print(response) diff --git a/docs/my-website/docs/proxy/caching.md b/docs/my-website/docs/proxy/caching.md index ee4874caf..4f1ce18f3 100644 --- a/docs/my-website/docs/proxy/caching.md +++ b/docs/my-website/docs/proxy/caching.md @@ -145,7 +145,7 @@ $ litellm --config /path/to/config.yaml Send the same request twice: ```shell -curl http://0.0.0.0:8000/v1/chat/completions \ +curl http://0.0.0.0:4000/v1/chat/completions \ -H "Content-Type: application/json" \ -d '{ "model": "gpt-3.5-turbo", @@ -153,7 +153,7 @@ curl http://0.0.0.0:8000/v1/chat/completions \ "temperature": 0.7 }' -curl http://0.0.0.0:8000/v1/chat/completions \ +curl http://0.0.0.0:4000/v1/chat/completions \ -H "Content-Type: application/json" \ -d '{ "model": "gpt-3.5-turbo", @@ -166,14 +166,14 @@ curl http://0.0.0.0:8000/v1/chat/completions \ Send the same request twice: ```shell -curl --location 'http://0.0.0.0:8000/embeddings' \ +curl --location 'http://0.0.0.0:4000/embeddings' \ --header 'Content-Type: application/json' \ --data ' { "model": "text-embedding-ada-002", "input": ["write a litellm poem"] }' -curl --location 'http://0.0.0.0:8000/embeddings' \ +curl --location 'http://0.0.0.0:4000/embeddings' \ --header 'Content-Type: application/json' \ --data ' { "model": "text-embedding-ada-002", @@ -227,7 +227,7 @@ from openai import OpenAI client = OpenAI( # This is the default and can be omitted api_key=os.environ.get("OPENAI_API_KEY"), - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) chat_completion = client.chat.completions.create( @@ -255,7 +255,7 @@ from openai import OpenAI client = OpenAI( # This is the default and can be omitted api_key=os.environ.get("OPENAI_API_KEY"), - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) chat_completion = client.chat.completions.create( @@ -281,7 +281,7 @@ from openai import OpenAI client = OpenAI( # This is the default and can be omitted api_key=os.environ.get("OPENAI_API_KEY"), - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) chat_completion = client.chat.completions.create( diff --git a/docs/my-website/docs/proxy/call_hooks.md b/docs/my-website/docs/proxy/call_hooks.md index b00f4e301..9d4d1112e 100644 --- a/docs/my-website/docs/proxy/call_hooks.md +++ b/docs/my-website/docs/proxy/call_hooks.md @@ -63,7 +63,7 @@ litellm_settings: $ litellm /path/to/config.yaml ``` ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --data ' { "model": "gpt-3.5-turbo", "messages": [ @@ -162,7 +162,7 @@ litellm_settings: $ litellm /path/to/config.yaml ``` ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --data ' { "model": "gpt-3.5-turbo", "messages": [ diff --git a/docs/my-website/docs/proxy/cli.md b/docs/my-website/docs/proxy/cli.md index d366f1f6b..28b210b16 100644 --- a/docs/my-website/docs/proxy/cli.md +++ b/docs/my-website/docs/proxy/cli.md @@ -15,7 +15,7 @@ Cli arguments, --host, --port, --num_workers ``` ## --port - - **Default:** `8000` + - **Default:** `4000` - The port to bind the server to. - **Usage:** ```shell diff --git a/docs/my-website/docs/proxy/configs.md b/docs/my-website/docs/proxy/configs.md index a863ec2ca..68b49502d 100644 --- a/docs/my-website/docs/proxy/configs.md +++ b/docs/my-website/docs/proxy/configs.md @@ -13,7 +13,7 @@ Set model list, `api_base`, `api_key`, `temperature` & proxy server settings (`m | `general_settings` | Server settings, example setting `master_key: sk-my_special_key` | | `environment_variables` | Environment Variables example, `REDIS_HOST`, `REDIS_PORT` | -**Complete List:** Check the Swagger UI docs on `/#/config.yaml` (e.g. http://0.0.0.0:8000/#/config.yaml), for everything you can pass in the config.yaml. +**Complete List:** Check the Swagger UI docs on `/#/config.yaml` (e.g. http://0.0.0.0:4000/#/config.yaml), for everything you can pass in the config.yaml. ## Quick Start @@ -55,7 +55,7 @@ model_list: - model_name: vllm-models litellm_params: model: openai/facebook/opt-125m # the `openai/` prefix tells litellm it's openai compatible - api_base: http://0.0.0.0:8000 + api_base: http://0.0.0.0:4000 rpm: 1440 model_info: version: 2 @@ -91,7 +91,7 @@ Sends request to model where `model_name=gpt-3.5-turbo` on config.yaml. If multiple with `model_name=gpt-3.5-turbo` does [Load Balancing](https://docs.litellm.ai/docs/proxy/load_balancing) ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "gpt-3.5-turbo", @@ -111,7 +111,7 @@ curl --location 'http://0.0.0.0:8000/chat/completions' \ Sends this request to model where `model_name=bedrock-claude-v1` on config.yaml ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "bedrock-claude-v1", @@ -131,7 +131,7 @@ curl --location 'http://0.0.0.0:8000/chat/completions' \ import openai client = openai.OpenAI( api_key="anything", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # Sends request to model where `model_name=gpt-3.5-turbo` on config.yaml. @@ -179,7 +179,7 @@ messages = [ # Sends request to model where `model_name=gpt-3.5-turbo` on config.yaml. chat = ChatOpenAI( - openai_api_base="http://0.0.0.0:8000", # set openai base to the proxy + openai_api_base="http://0.0.0.0:4000", # set openai base to the proxy model = "gpt-3.5-turbo", temperature=0.1 ) @@ -189,7 +189,7 @@ print(response) # Sends request to model where `model_name=bedrock-claude-v1` on config.yaml. claude_chat = ChatOpenAI( - openai_api_base="http://0.0.0.0:8000", # set openai base to the proxy + openai_api_base="http://0.0.0.0:4000", # set openai base to the proxy model = "bedrock-claude-v1", temperature=0.1 ) @@ -560,7 +560,7 @@ litellm --config config.yaml Sends Request to `bedrock-cohere` ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "bedrock-cohere", diff --git a/docs/my-website/docs/proxy/deploy.md b/docs/my-website/docs/proxy/deploy.md index 496bde05f..1a0d3abad 100644 --- a/docs/my-website/docs/proxy/deploy.md +++ b/docs/my-website/docs/proxy/deploy.md @@ -241,10 +241,10 @@ helm install \ kubectl \ port-forward \ service/mydeploy-litellm \ - 8000:8000 + 4000:4000 ``` -Your OpenAI proxy server is now running on `http://127.0.0.1:8000`. +Your OpenAI proxy server is now running on `http://127.0.0.1:4000`. @@ -393,11 +393,11 @@ services: target: runtime image: ghcr.io/berriai/litellm:main-latest ports: - - "8000:8000" # Map the container port to the host, change the host port if necessary + - "4000:4000" # Map the container port to the host, change the host port if necessary volumes: - ./litellm-config.yaml:/app/config.yaml # Mount the local configuration file # You can change the port or number of workers as per your requirements or pass any new supported CLI augument. Make sure the port passed here matches with the container port defined above in `ports` value - command: [ "--config", "/app/config.yaml", "--port", "8000", "--num_workers", "8" ] + command: [ "--config", "/app/config.yaml", "--port", "4000", "--num_workers", "8" ] # ...rest of your docker-compose config if any ``` @@ -415,4 +415,4 @@ Run the command `docker-compose up` or `docker compose up` as per your docker in > Use `-d` flag to run the container in detached mode (background) e.g. `docker compose up -d` -Your LiteLLM container should be running now on the defined port e.g. `8000`. +Your LiteLLM container should be running now on the defined port e.g. `4000`. diff --git a/docs/my-website/docs/proxy/embedding.md b/docs/my-website/docs/proxy/embedding.md index 0f3a01a90..2adaaa247 100644 --- a/docs/my-website/docs/proxy/embedding.md +++ b/docs/my-website/docs/proxy/embedding.md @@ -38,7 +38,7 @@ $ litellm --config /path/to/config.yaml 3. Test the embedding call ```shell -curl --location 'http://0.0.0.0:8000/v1/embeddings' \ +curl --location 'http://0.0.0.0:4000/v1/embeddings' \ --header 'Authorization: Bearer sk-1234' \ --header 'Content-Type: application/json' \ --data '{ diff --git a/docs/my-website/docs/proxy/enterprise.md b/docs/my-website/docs/proxy/enterprise.md index e0c5374f0..93786eff4 100644 --- a/docs/my-website/docs/proxy/enterprise.md +++ b/docs/my-website/docs/proxy/enterprise.md @@ -58,7 +58,7 @@ callbacks: ["llamaguard_moderations"] Set the LLM Guard API Base in your environment ```env -LLM_GUARD_API_BASE = "http://0.0.0.0:8000" +LLM_GUARD_API_BASE = "http://0.0.0.0:4000" ``` Add `llmguard_moderations` as a callback @@ -143,7 +143,7 @@ When `no-log=True`, the request will **not be logged on any callbacks** and ther import openai client = openai.OpenAI( api_key="anything", # proxy api-key - base_url="http://0.0.0.0:8000" # litellm proxy + base_url="http://0.0.0.0:4000" # litellm proxy ) response = client.chat.completions.create( @@ -175,7 +175,7 @@ litellm_settings: ### How to test ```bash -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "gpt-3.5-turbo", @@ -202,7 +202,7 @@ curl --location 'http://0.0.0.0:8000/chat/completions' \ **Block all calls for a user id** ``` -curl -X POST "http://0.0.0.0:8000/user/block" \ +curl -X POST "http://0.0.0.0:4000/user/block" \ -H "Authorization: Bearer sk-1234" \ -D '{ "user_ids": [, ...] @@ -212,7 +212,7 @@ curl -X POST "http://0.0.0.0:8000/user/block" \ **Unblock calls for a user id** ``` -curl -X POST "http://0.0.0.0:8000/user/unblock" \ +curl -X POST "http://0.0.0.0:4000/user/unblock" \ -H "Authorization: Bearer sk-1234" \ -D '{ "user_ids": [, ...] @@ -230,7 +230,7 @@ litellm_settings: ### Test this ```bash -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "gpt-3.5-turbo", @@ -263,7 +263,7 @@ Set `extra_body={"metadata": { }}` to `metadata` you want to pass import openai client = openai.OpenAI( api_key="anything", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # request sent to model set on litellm proxy, `litellm --model` @@ -291,7 +291,7 @@ print(response) Pass `metadata` as part of the request body ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data '{ "model": "gpt-3.5-turbo", @@ -317,7 +317,7 @@ from langchain.prompts.chat import ( from langchain.schema import HumanMessage, SystemMessage chat = ChatOpenAI( - openai_api_base="http://0.0.0.0:8000", + openai_api_base="http://0.0.0.0:4000", model = "gpt-3.5-turbo", temperature=0.1, extra_body={ diff --git a/docs/my-website/docs/proxy/health.md b/docs/my-website/docs/proxy/health.md index f0b797329..03dd91731 100644 --- a/docs/my-website/docs/proxy/health.md +++ b/docs/my-website/docs/proxy/health.md @@ -12,10 +12,10 @@ The proxy exposes: #### Request Make a GET Request to `/health` on the proxy ```shell -curl --location 'http://0.0.0.0:8000/health' -H "Authorization: Bearer sk-1234" +curl --location 'http://0.0.0.0:4000/health' -H "Authorization: Bearer sk-1234" ``` -You can also run `litellm -health` it makes a `get` request to `http://0.0.0.0:8000/health` for you +You can also run `litellm -health` it makes a `get` request to `http://0.0.0.0:4000/health` for you ``` litellm --health ``` @@ -60,7 +60,7 @@ $ litellm /path/to/config.yaml 3. Query health endpoint: ``` -curl --location 'http://0.0.0.0:8000/health' +curl --location 'http://0.0.0.0:4000/health' ``` ### Embedding Models @@ -119,7 +119,7 @@ Unprotected endpoint for checking if proxy is ready to accept requests Example Request: ```bash -curl --location 'http://0.0.0.0:8000/health/readiness' +curl --location 'http://0.0.0.0:4000/health/readiness' ``` Example Response: @@ -153,7 +153,7 @@ Example Request: ``` curl -X 'GET' \ - 'http://0.0.0.0:8000/health/liveliness' \ + 'http://0.0.0.0:4000/health/liveliness' \ -H 'accept: application/json' ``` diff --git a/docs/my-website/docs/proxy/load_balancing.md b/docs/my-website/docs/proxy/load_balancing.md index ad5e91203..691592cb6 100644 --- a/docs/my-website/docs/proxy/load_balancing.md +++ b/docs/my-website/docs/proxy/load_balancing.md @@ -45,7 +45,7 @@ $ litellm --config /path/to/config.yaml ### Step 3: Use proxy - Call a model group [Load Balancing] Curl Command ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "gpt-3.5-turbo", @@ -65,7 +65,7 @@ If you want to call a specific model defined in the `config.yaml`, you can call In this example it will call `azure/gpt-turbo-small-ca`. Defined in the config on Step 1 ```bash -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "azure/gpt-turbo-small-ca", diff --git a/docs/my-website/docs/proxy/logging.md b/docs/my-website/docs/proxy/logging.md index bf4216c0e..589199a07 100644 --- a/docs/my-website/docs/proxy/logging.md +++ b/docs/my-website/docs/proxy/logging.md @@ -150,7 +150,7 @@ litellm --config proxy_config.yaml ``` ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Authorization: Bearer sk-1234' \ --data ' { "model": "gpt-3.5-turbo", @@ -174,7 +174,7 @@ On Success Usage: {'completion_tokens': 10, 'prompt_tokens': 11, 'total_tokens': 21}, Cost: 3.65e-05, Response: {'id': 'chatcmpl-8S8avKJ1aVBg941y5xzGMSKrYCMvN', 'choices': [{'finish_reason': 'stop', 'index': 0, 'message': {'content': 'Good morning! How can I assist you today?', 'role': 'assistant'}}], 'created': 1701716913, 'model': 'gpt-3.5-turbo-0613', 'object': 'chat.completion', 'system_fingerprint': None, 'usage': {'completion_tokens': 10, 'prompt_tokens': 11, 'total_tokens': 21}} - Proxy Metadata: {'user_api_key': None, 'headers': Headers({'host': '0.0.0.0:8000', 'user-agent': 'curl/7.88.1', 'accept': '*/*', 'authorization': 'Bearer sk-1234', 'content-length': '199', 'content-type': 'application/x-www-form-urlencoded'}), 'model_group': 'gpt-3.5-turbo', 'deployment': 'gpt-3.5-turbo-ModelID-gpt-3.5-turbo'} + Proxy Metadata: {'user_api_key': None, 'headers': Headers({'host': '0.0.0.0:4000', 'user-agent': 'curl/7.88.1', 'accept': '*/*', 'authorization': 'Bearer sk-1234', 'content-length': '199', 'content-type': 'application/x-www-form-urlencoded'}), 'model_group': 'gpt-3.5-turbo', 'deployment': 'gpt-3.5-turbo-ModelID-gpt-3.5-turbo'} ``` #### Logging Proxy Request Object, Header, Url @@ -374,7 +374,7 @@ async def log_event(request: Request): if __name__ == "__main__": import uvicorn - uvicorn.run(app, host="127.0.0.1", port=8000) + uvicorn.run(app, host="127.0.0.1", port=4000) ``` @@ -383,7 +383,7 @@ if __name__ == "__main__": #### Step 2. Set your `GENERIC_LOGGER_ENDPOINT` to the endpoint + route we should send callback logs to ```shell -os.environ["GENERIC_LOGGER_ENDPOINT"] = "http://localhost:8000/log-event" +os.environ["GENERIC_LOGGER_ENDPOINT"] = "http://localhost:4000/log-event" ``` #### Step 3. Create a `config.yaml` file and set `litellm_settings`: `success_callback` = ["generic"] @@ -445,7 +445,7 @@ Expected output on Langfuse Pass `metadata` as part of the request body ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data '{ "model": "gpt-3.5-turbo", @@ -472,7 +472,7 @@ Set `extra_body={"metadata": { }}` to `metadata` you want to pass import openai client = openai.OpenAI( api_key="anything", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # request sent to model set on litellm proxy, `litellm --model` @@ -509,7 +509,7 @@ from langchain.prompts.chat import ( from langchain.schema import HumanMessage, SystemMessage chat = ChatOpenAI( - openai_api_base="http://0.0.0.0:8000", + openai_api_base="http://0.0.0.0:4000", model = "gpt-3.5-turbo", temperature=0.1, extra_body={ @@ -663,7 +663,7 @@ litellm --config config.yaml --debug Test Request ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "Azure OpenAI GPT-4 East", @@ -698,7 +698,7 @@ litellm_settings: Now, when you [generate keys](./virtual_keys.md) for this team-id ```bash -curl -X POST 'http://0.0.0.0:8000/key/generate' \ +curl -X POST 'http://0.0.0.0:4000/key/generate' \ -H 'Authorization: Bearer sk-1234' \ -H 'Content-Type: application/json' \ -D '{"team_id": "ishaans-secret-project"}' @@ -742,7 +742,7 @@ litellm --config config.yaml --debug Test Request ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "Azure OpenAI GPT-4 East", @@ -903,7 +903,7 @@ litellm --config config.yaml --debug Test Request ``` -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "gpt-3.5-turbo", @@ -947,7 +947,7 @@ litellm --config config.yaml --debug Test Request ``` -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "gpt-3.5-turbo", diff --git a/docs/my-website/docs/proxy/model_management.md b/docs/my-website/docs/proxy/model_management.md index 8160e2aa7..0a236185f 100644 --- a/docs/my-website/docs/proxy/model_management.md +++ b/docs/my-website/docs/proxy/model_management.md @@ -24,7 +24,7 @@ Retrieve detailed information about each model listed in the `/models` endpoint, ```bash -curl -X GET "http://0.0.0.0:8000/model/info" \ +curl -X GET "http://0.0.0.0:4000/model/info" \ -H "accept: application/json" \ ``` @@ -42,7 +42,7 @@ Add a new model to the list in the `config.yaml` by providing the model paramete ```bash -curl -X POST "http://0.0.0.0:8000/model/new" \ +curl -X POST "http://0.0.0.0:4000/model/new" \ -H "accept: application/json" \ -H "Content-Type: application/json" \ -d '{ "model_name": "azure-gpt-turbo", "litellm_params": {"model": "azure/gpt-3.5-turbo", "api_key": "os.environ/AZURE_API_KEY", "api_base": "my-azure-api-base"} }' diff --git a/docs/my-website/docs/proxy/pii_masking.md b/docs/my-website/docs/proxy/pii_masking.md index 0d559d910..a95a6d771 100644 --- a/docs/my-website/docs/proxy/pii_masking.md +++ b/docs/my-website/docs/proxy/pii_masking.md @@ -96,7 +96,7 @@ Turn off PII masking for a given key. Do this by setting `permissions: {"pii": false}`, when generating a key. ```shell -curl --location 'http://0.0.0.0:8000/key/generate' \ +curl --location 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer sk-1234' \ --header 'Content-Type: application/json' \ --data '{ @@ -119,7 +119,7 @@ The proxy support 2 request-level PII controls: Set `allow_pii_controls` to true for a given key. This will allow the user to set request-level PII controls. ```bash -curl --location 'http://0.0.0.0:8000/key/generate' \ +curl --location 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer my-master-key' \ --header 'Content-Type: application/json' \ --data '{ @@ -136,7 +136,7 @@ from openai import OpenAI client = OpenAI( # This is the default and can be omitted api_key=os.environ.get("OPENAI_API_KEY"), - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) chat_completion = client.chat.completions.create( diff --git a/docs/my-website/docs/proxy/quick_start.md b/docs/my-website/docs/proxy/quick_start.md index 4f508ee59..d44970348 100644 --- a/docs/my-website/docs/proxy/quick_start.md +++ b/docs/my-website/docs/proxy/quick_start.md @@ -21,7 +21,7 @@ Run the following command to start the litellm proxy ```shell $ litellm --model huggingface/bigcode/starcoder -#INFO: Proxy running on http://0.0.0.0:8000 +#INFO: Proxy running on http://0.0.0.0:4000 ``` ### Test @@ -250,7 +250,7 @@ litellm --config your_config.yaml ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "gpt-3.5-turbo", @@ -270,7 +270,7 @@ curl --location 'http://0.0.0.0:8000/chat/completions' \ import openai client = openai.OpenAI( api_key="anything", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # request sent to model set on litellm proxy, `litellm --model` @@ -297,7 +297,7 @@ from langchain.prompts.chat import ( from langchain.schema import HumanMessage, SystemMessage chat = ChatOpenAI( - openai_api_base="http://0.0.0.0:8000", # set openai_api_base to the LiteLLM Proxy + openai_api_base="http://0.0.0.0:4000", # set openai_api_base to the LiteLLM Proxy model = "gpt-3.5-turbo", temperature=0.1 ) @@ -321,7 +321,7 @@ print(response) ```python from langchain.embeddings import OpenAIEmbeddings -embeddings = OpenAIEmbeddings(model="sagemaker-embeddings", openai_api_base="http://0.0.0.0:8000", openai_api_key="temp-key") +embeddings = OpenAIEmbeddings(model="sagemaker-embeddings", openai_api_base="http://0.0.0.0:4000", openai_api_key="temp-key") text = "This is a test document." @@ -331,7 +331,7 @@ query_result = embeddings.embed_query(text) print(f"SAGEMAKER EMBEDDINGS") print(query_result[:5]) -embeddings = OpenAIEmbeddings(model="bedrock-embeddings", openai_api_base="http://0.0.0.0:8000", openai_api_key="temp-key") +embeddings = OpenAIEmbeddings(model="bedrock-embeddings", openai_api_base="http://0.0.0.0:4000", openai_api_key="temp-key") text = "This is a test document." @@ -340,7 +340,7 @@ query_result = embeddings.embed_query(text) print(f"BEDROCK EMBEDDINGS") print(query_result[:5]) -embeddings = OpenAIEmbeddings(model="bedrock-titan-embeddings", openai_api_base="http://0.0.0.0:8000", openai_api_key="temp-key") +embeddings = OpenAIEmbeddings(model="bedrock-titan-embeddings", openai_api_base="http://0.0.0.0:4000", openai_api_key="temp-key") text = "This is a test document." @@ -407,11 +407,11 @@ services: litellm: image: ghcr.io/berriai/litellm:main ports: - - "8000:8000" # Map the container port to the host, change the host port if necessary + - "4000:4000" # Map the container port to the host, change the host port if necessary volumes: - ./litellm-config.yaml:/app/config.yaml # Mount the local configuration file # You can change the port or number of workers as per your requirements or pass any new supported CLI augument. Make sure the port passed here matches with the container port defined above in `ports` value - command: [ "--config", "/app/config.yaml", "--port", "8000", "--num_workers", "8" ] + command: [ "--config", "/app/config.yaml", "--port", "4000", "--num_workers", "8" ] # ...rest of your docker-compose config if any ``` @@ -429,7 +429,7 @@ Run the command `docker-compose up` or `docker compose up` as per your docker in > Use `-d` flag to run the container in detached mode (background) e.g. `docker compose up -d` -Your LiteLLM container should be running now on the defined port e.g. `8000`. +Your LiteLLM container should be running now on the defined port e.g. `4000`. ## Using with OpenAI compatible projects @@ -442,7 +442,7 @@ Set `base_url` to the LiteLLM Proxy server import openai client = openai.OpenAI( api_key="anything", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # request sent to model set on litellm proxy, `litellm --model` @@ -463,7 +463,7 @@ print(response) ```shell litellm --model gpt-3.5-turbo -#INFO: Proxy running on http://0.0.0.0:8000 +#INFO: Proxy running on http://0.0.0.0:4000 ``` #### 1. Clone the repo @@ -474,9 +474,9 @@ git clone https://github.com/danny-avila/LibreChat.git #### 2. Modify Librechat's `docker-compose.yml` -LiteLLM Proxy is running on port `8000`, set `8000` as the proxy below +LiteLLM Proxy is running on port `4000`, set `4000` as the proxy below ```yaml -OPENAI_REVERSE_PROXY=http://host.docker.internal:8000/v1/chat/completions +OPENAI_REVERSE_PROXY=http://host.docker.internal:4000/v1/chat/completions ``` #### 3. Save fake OpenAI key in Librechat's `.env` @@ -502,7 +502,7 @@ In the [config.py](https://continue.dev/docs/reference/Models/openai) set this a api_key="IGNORED", model="fake-model-name", context_length=2048, # customize if needed for your model - api_base="http://localhost:8000" # your proxy server url + api_base="http://localhost:4000" # your proxy server url ), ``` @@ -514,7 +514,7 @@ Credits [@vividfog](https://github.com/jmorganca/ollama/issues/305#issuecomment- ```shell $ pip install aider -$ aider --openai-api-base http://0.0.0.0:8000 --openai-api-key fake-key +$ aider --openai-api-base http://0.0.0.0:4000 --openai-api-key fake-key ``` @@ -528,7 +528,7 @@ from autogen import AssistantAgent, UserProxyAgent, oai config_list=[ { "model": "my-fake-model", - "api_base": "http://localhost:8000", #litellm compatible endpoint + "api_base": "http://localhost:4000", #litellm compatible endpoint "api_type": "open_ai", "api_key": "NULL", # just a placeholder } @@ -566,7 +566,7 @@ import guidance # set api_base to your proxy # set api_key to anything -gpt4 = guidance.llms.OpenAI("gpt-4", api_base="http://0.0.0.0:8000", api_key="anything") +gpt4 = guidance.llms.OpenAI("gpt-4", api_base="http://0.0.0.0:4000", api_key="anything") experts = guidance(''' {{#system~}} diff --git a/docs/my-website/docs/proxy/reliability.md b/docs/my-website/docs/proxy/reliability.md index f241e4ec0..7527a3d5b 100644 --- a/docs/my-website/docs/proxy/reliability.md +++ b/docs/my-website/docs/proxy/reliability.md @@ -45,7 +45,7 @@ litellm_settings: **Set dynamically** ```bash -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "zephyr-beta", @@ -101,7 +101,7 @@ LiteLLM Proxy supports setting a `timeout` per request ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data-raw '{ "model": "gpt-3.5-turbo", @@ -121,7 +121,7 @@ import openai client = openai.OpenAI( api_key="anything", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) response = client.chat.completions.create( diff --git a/docs/my-website/docs/proxy/rules.md b/docs/my-website/docs/proxy/rules.md index 415607b61..60e990d91 100644 --- a/docs/my-website/docs/proxy/rules.md +++ b/docs/my-website/docs/proxy/rules.md @@ -30,7 +30,7 @@ $ litellm /path/to/config.yaml ``` ```bash -curl --location 'http://0.0.0.0:8000/v1/chat/completions' \ +curl --location 'http://0.0.0.0:4000/v1/chat/completions' \ --header 'Content-Type: application/json' \ --header 'Authorization: Bearer sk-1234' \ --data '{ diff --git a/docs/my-website/docs/proxy/streaming_logging.md b/docs/my-website/docs/proxy/streaming_logging.md index 6bc5882d1..3fa896467 100644 --- a/docs/my-website/docs/proxy/streaming_logging.md +++ b/docs/my-website/docs/proxy/streaming_logging.md @@ -65,7 +65,7 @@ litellm --config proxy_config.yaml ``` ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Authorization: Bearer sk-1234' \ --data ' { "model": "gpt-3.5-turbo", diff --git a/docs/my-website/docs/proxy/ui.md b/docs/my-website/docs/proxy/ui.md index 188a2a2eb..cca9d4434 100644 --- a/docs/my-website/docs/proxy/ui.md +++ b/docs/my-website/docs/proxy/ui.md @@ -28,12 +28,12 @@ Follow [setup](./virtual_keys.md#setup) ```bash litellm --config /path/to/config.yaml -#INFO: Proxy running on http://0.0.0.0:8000 +#INFO: Proxy running on http://0.0.0.0:4000 ``` ### 2. Go to UI ```bash -http://0.0.0.0:8000/ui # /ui +http://0.0.0.0:4000/ui # /ui ``` diff --git a/docs/my-website/docs/proxy/user_keys.md b/docs/my-website/docs/proxy/user_keys.md index fcccffaa0..d86d3ae09 100644 --- a/docs/my-website/docs/proxy/user_keys.md +++ b/docs/my-website/docs/proxy/user_keys.md @@ -26,7 +26,7 @@ Set `extra_body={"metadata": { }}` to `metadata` you want to pass import openai client = openai.OpenAI( api_key="anything", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # request sent to model set on litellm proxy, `litellm --model` @@ -92,7 +92,7 @@ print(response) Pass `metadata` as part of the request body ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data '{ "model": "gpt-3.5-turbo", @@ -123,7 +123,7 @@ from langchain.prompts.chat import ( from langchain.schema import HumanMessage, SystemMessage chat = ChatOpenAI( - openai_api_base="http://0.0.0.0:8000", + openai_api_base="http://0.0.0.0:4000", model = "gpt-3.5-turbo", temperature=0.1, extra_body={ @@ -195,7 +195,7 @@ from openai import OpenAI # set base_url to your proxy server # set api_key to send to proxy server -client = OpenAI(api_key="", base_url="http://0.0.0.0:8000") +client = OpenAI(api_key="", base_url="http://0.0.0.0:4000") response = client.embeddings.create( input=["hello from litellm"], @@ -209,7 +209,7 @@ print(response) ```shell -curl --location 'http://0.0.0.0:8000/embeddings' \ +curl --location 'http://0.0.0.0:4000/embeddings' \ --header 'Content-Type: application/json' \ --data ' { "model": "text-embedding-ada-002", @@ -223,7 +223,7 @@ curl --location 'http://0.0.0.0:8000/embeddings' \ ```python from langchain.embeddings import OpenAIEmbeddings -embeddings = OpenAIEmbeddings(model="sagemaker-embeddings", openai_api_base="http://0.0.0.0:8000", openai_api_key="temp-key") +embeddings = OpenAIEmbeddings(model="sagemaker-embeddings", openai_api_base="http://0.0.0.0:4000", openai_api_key="temp-key") text = "This is a test document." @@ -233,7 +233,7 @@ query_result = embeddings.embed_query(text) print(f"SAGEMAKER EMBEDDINGS") print(query_result[:5]) -embeddings = OpenAIEmbeddings(model="bedrock-embeddings", openai_api_base="http://0.0.0.0:8000", openai_api_key="temp-key") +embeddings = OpenAIEmbeddings(model="bedrock-embeddings", openai_api_base="http://0.0.0.0:4000", openai_api_key="temp-key") text = "This is a test document." @@ -242,7 +242,7 @@ query_result = embeddings.embed_query(text) print(f"BEDROCK EMBEDDINGS") print(query_result[:5]) -embeddings = OpenAIEmbeddings(model="bedrock-titan-embeddings", openai_api_base="http://0.0.0.0:8000", openai_api_key="temp-key") +embeddings = OpenAIEmbeddings(model="bedrock-titan-embeddings", openai_api_base="http://0.0.0.0:4000", openai_api_key="temp-key") text = "This is a test document." @@ -296,7 +296,7 @@ from openai import OpenAI # set base_url to your proxy server # set api_key to send to proxy server -client = OpenAI(api_key="", base_url="http://0.0.0.0:8000") +client = OpenAI(api_key="", base_url="http://0.0.0.0:4000") response = client.moderations.create( input="hello from litellm", @@ -310,7 +310,7 @@ print(response) ```shell -curl --location 'http://0.0.0.0:8000/moderations' \ +curl --location 'http://0.0.0.0:4000/moderations' \ --header 'Content-Type: application/json' \ --header 'Authorization: Bearer sk-1234' \ --data '{"input": "Sample text goes here", "model": "text-moderation-stable"}' @@ -421,7 +421,7 @@ user_config = { import openai client = openai.OpenAI( api_key="sk-1234", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # send request to `user-azure-instance` @@ -489,7 +489,7 @@ const { OpenAI } = require('openai'); const openai = new OpenAI({ apiKey: "sk-1234", - baseURL: "http://0.0.0.0:8000" + baseURL: "http://0.0.0.0:4000" }); async function main() { @@ -516,7 +516,7 @@ Here's how to do it: import openai client = openai.OpenAI( api_key="sk-1234", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # request sent to model set on litellm proxy, `litellm --model` @@ -541,7 +541,7 @@ Pass in the litellm_params (E.g. api_key, api_base, etc.) via the `extra_body` p import openai client = openai.OpenAI( api_key="sk-1234", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # request sent to model set on litellm proxy, `litellm --model` @@ -571,7 +571,7 @@ const { OpenAI } = require('openai'); const openai = new OpenAI({ apiKey: "sk-1234", - baseURL: "http://0.0.0.0:8000" + baseURL: "http://0.0.0.0:4000" }); async function main() { diff --git a/docs/my-website/docs/proxy/users.md b/docs/my-website/docs/proxy/users.md index 9c8927caf..12cbda9d0 100644 --- a/docs/my-website/docs/proxy/users.md +++ b/docs/my-website/docs/proxy/users.md @@ -44,7 +44,7 @@ litellm /path/to/config.yaml **Step 3. Send test call** ```bash -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Autherization: Bearer sk-1234' \ --header 'Content-Type: application/json' \ --data '{ @@ -72,7 +72,7 @@ By default the `max_budget` is set to `null` and is not checked for keys #### **Add budgets to users** ```shell -curl --location 'http://localhost:8000/user/new' \ +curl --location 'http://localhost:4000/user/new' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{"models": ["azure-models"], "max_budget": 0, "user_id": "krrish3@berri.ai"}' @@ -96,7 +96,7 @@ curl --location 'http://localhost:8000/user/new' \ `budget_duration`: Budget is reset at the end of specified duration. If not set, budget is never reset. You can set duration as seconds ("30s"), minutes ("30m"), hours ("30h"), days ("30d"). ``` -curl 'http://0.0.0.0:8000/user/new' \ +curl 'http://0.0.0.0:4000/user/new' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{ @@ -113,7 +113,7 @@ Now you can just call `/key/generate` with that user_id (i.e. krrish3@berri.ai) - **Spend Tracking**: spend for this key will update krrish3@berri.ai's spend as well ```bash -curl --location 'http://0.0.0.0:8000/key/generate' \ +curl --location 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data '{"models": ["azure-models"], "user_id": "krrish3@berri.ai"}' @@ -127,7 +127,7 @@ You can: #### **Add budgets to users** ```shell -curl --location 'http://localhost:8000/team/new' \ +curl --location 'http://localhost:4000/team/new' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{ @@ -238,7 +238,7 @@ By default the `max_budget` is set to `null` and is not checked for keys #### **Add budgets to keys** ```bash -curl 'http://0.0.0.0:8000/key/generate' \ +curl 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{ @@ -250,7 +250,7 @@ curl 'http://0.0.0.0:8000/key/generate' \ Example Request to `/chat/completions` when key has crossed budget ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --header 'Authorization: Bearer ' \ --data ' { @@ -278,7 +278,7 @@ Expected Response from `/chat/completions` when key has crossed budget `budget_duration`: Budget is reset at the end of specified duration. If not set, budget is never reset. You can set duration as seconds ("30s"), minutes ("30m"), hours ("30h"), days ("30d"). ``` -curl 'http://0.0.0.0:8000/key/generate' \ +curl 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{ @@ -310,7 +310,7 @@ By default the `model_max_budget` is set to `{}` and is not checked for keys #### **Add model specific budgets to keys** ```bash -curl 'http://0.0.0.0:8000/key/generate' \ +curl 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{ @@ -335,7 +335,7 @@ Use `/user/new`, to persist rate limits across multiple keys. ```shell -curl --location 'http://0.0.0.0:8000/user/new' \ +curl --location 'http://0.0.0.0:4000/user/new' \ --header 'Authorization: Bearer sk-1234' \ --header 'Content-Type: application/json' \ --data '{"user_id": "krrish@berri.ai", "max_parallel_requests": 10, "tpm_limit": 20, "rpm_limit": 4}' @@ -359,7 +359,7 @@ curl --location 'http://0.0.0.0:8000/user/new' \ Use `/key/generate`, if you want them for just that key. ```shell -curl --location 'http://0.0.0.0:8000/key/generate' \ +curl --location 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer sk-1234' \ --header 'Content-Type: application/json' \ --data '{"max_parallel_requests": 10, "tpm_limit": 20, "rpm_limit": 4}' @@ -401,7 +401,7 @@ model_list: **Step 2. Create key with access group** ```bash -curl --location 'http://localhost:8000/user/new' \ +curl --location 'http://localhost:4000/user/new' \ -H 'Authorization: Bearer ' \ -H 'Content-Type: application/json' \ -d '{"models": ["beta-models"], # 👈 Model Access Group @@ -414,7 +414,7 @@ curl --location 'http://localhost:8000/user/new' \ Just include user_id in the `/key/generate` request. ```bash -curl --location 'http://0.0.0.0:8000/key/generate' \ +curl --location 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data '{"models": ["azure-models"], "user_id": "krrish@berri.ai"}' diff --git a/docs/my-website/docs/proxy/virtual_keys.md b/docs/my-website/docs/proxy/virtual_keys.md index 70fd6e6a8..e84b3c16f 100644 --- a/docs/my-website/docs/proxy/virtual_keys.md +++ b/docs/my-website/docs/proxy/virtual_keys.md @@ -59,7 +59,7 @@ litellm --config /path/to/config.yaml **Step 3: Generate temporary keys** ```shell -curl 'http://0.0.0.0:8000/key/generate' \ +curl 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{"models": ["gpt-3.5-turbo", "gpt-4", "claude-2"], "duration": "20m","metadata": {"user": "ishaan@berri.ai"}}' @@ -70,7 +70,7 @@ curl 'http://0.0.0.0:8000/key/generate' \ ### Request ```shell -curl 'http://0.0.0.0:8000/key/generate' \ +curl 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{ @@ -105,7 +105,7 @@ Request Params: ```python { "key": "sk-kdEXbIqZRwEeEiHwdg7sFA", # Bearer token - "expires": "2023-11-19T01:38:25.838000+00:00" # datetime object + "expires": "2023-11-19T01:38:25.834000+00:00" # datetime object "key_name": "sk-...7sFA" # abbreviated key string, ONLY stored in db if `allow_user_auth: true` set - [see](./ui.md) ... } @@ -147,7 +147,7 @@ model_list: **Step 2: Generate a user key - enabling them access to specific models, custom model aliases, etc.** ```bash -curl -X POST "https://0.0.0.0:8000/key/generate" \ +curl -X POST "https://0.0.0.0:4000/key/generate" \ -H "Authorization: Bearer " \ -H "Content-Type: application/json" \ -d '{ @@ -182,7 +182,7 @@ model_list: **Step 2. Create key with access group** ```bash -curl --location 'http://localhost:8000/key/generate' \ +curl --location 'http://localhost:4000/key/generate' \ -H 'Authorization: Bearer ' \ -H 'Content-Type: application/json' \ -d '{"models": ["beta-models"], # 👈 Model Access Group @@ -194,7 +194,7 @@ curl --location 'http://localhost:8000/key/generate' \ ### Request ```shell -curl -X GET "http://0.0.0.0:8000/key/info?key=sk-02Wr4IAlN3NvPXvL5JVvDA" \ +curl -X GET "http://0.0.0.0:4000/key/info?key=sk-02Wr4IAlN3NvPXvL5JVvDA" \ -H "Authorization: Bearer sk-1234" ``` @@ -228,7 +228,7 @@ Request Params: ### Request ```shell -curl 'http://0.0.0.0:8000/key/update' \ +curl 'http://0.0.0.0:4000/key/update' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{ @@ -266,7 +266,7 @@ Request Params: ### Request ```shell -curl 'http://0.0.0.0:8000/key/delete' \ +curl 'http://0.0.0.0:4000/key/delete' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{ @@ -500,7 +500,7 @@ curl --location 'http://0.0.0.0:4000/chat/completions' \ Set `max_budget` in (USD $) param in the `key/generate` request. By default the `max_budget` is set to `null` and is not checked for keys ```shell -curl 'http://0.0.0.0:8000/key/generate' \ +curl 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{ @@ -517,7 +517,7 @@ curl 'http://0.0.0.0:8000/key/generate' \ Example Request to `/chat/completions` when key has crossed budget ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --header 'Authorization: Bearer sk-ULl_IKCVFy2EZRzQB16RUA' \ --data ' { @@ -545,10 +545,10 @@ Expected Response from `/chat/completions` when key has crossed budget LiteLLM exposes a `/user/new` endpoint to create budgets for users, that persist across multiple keys. -This is documented in the swagger (live on your server root endpoint - e.g. `http://0.0.0.0:8000/`). Here's an example request. +This is documented in the swagger (live on your server root endpoint - e.g. `http://0.0.0.0:4000/`). Here's an example request. ```shell -curl --location 'http://localhost:8000/user/new' \ +curl --location 'http://localhost:4000/user/new' \ --header 'Authorization: Bearer ' \ --header 'Content-Type: application/json' \ --data-raw '{"models": ["azure-models"], "max_budget": 0, "user_id": "krrish3@berri.ai"}' @@ -571,7 +571,7 @@ The request is a normal `/key/generate` request body + a `max_budget` field. You can get spend for a key by using the `/key/info` endpoint. ```bash -curl 'http://0.0.0.0:8000/key/info?key=' \ +curl 'http://0.0.0.0:4000/key/info?key=' \ -X GET \ -H 'Authorization: Bearer ' ``` @@ -771,7 +771,7 @@ general_settings: #### Step 3. Generate Key ```bash -curl --location 'http://0.0.0.0:8000/key/generate' \ +curl --location 'http://0.0.0.0:4000/key/generate' \ --header 'Authorization: Bearer sk-1234' \ --header 'Content-Type: application/json' \ --data '{"models": ["azure-models"], "aliases": {"mistral-7b": "gpt-3.5-turbo"}, "duration": null}' diff --git a/docs/my-website/docs/simple_proxy_old_doc.md b/docs/my-website/docs/simple_proxy_old_doc.md index b48e345e1..9dcb27797 100644 --- a/docs/my-website/docs/simple_proxy_old_doc.md +++ b/docs/my-website/docs/simple_proxy_old_doc.md @@ -22,7 +22,7 @@ $ pip install 'litellm[proxy]' ```shell $ litellm --model huggingface/bigcode/starcoder -#INFO: Proxy running on http://0.0.0.0:8000 +#INFO: Proxy running on http://0.0.0.0:4000 ``` ### Test @@ -39,7 +39,7 @@ This will now automatically route any requests for gpt-3.5-turbo to bigcode star ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "gpt-3.5-turbo", @@ -59,7 +59,7 @@ curl --location 'http://0.0.0.0:8000/chat/completions' \ import openai client = openai.OpenAI( api_key="anything", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # request sent to model set on litellm proxy, `litellm --model` @@ -246,7 +246,7 @@ Set `base_url` to the LiteLLM Proxy server import openai client = openai.OpenAI( api_key="anything", - base_url="http://0.0.0.0:8000" + base_url="http://0.0.0.0:4000" ) # request sent to model set on litellm proxy, `litellm --model` @@ -267,7 +267,7 @@ print(response) ```shell litellm --model gpt-3.5-turbo -#INFO: Proxy running on http://0.0.0.0:8000 +#INFO: Proxy running on http://0.0.0.0:4000 ``` #### 1. Clone the repo @@ -278,9 +278,9 @@ git clone https://github.com/danny-avila/LibreChat.git #### 2. Modify Librechat's `docker-compose.yml` -LiteLLM Proxy is running on port `8000`, set `8000` as the proxy below +LiteLLM Proxy is running on port `4000`, set `4000` as the proxy below ```yaml -OPENAI_REVERSE_PROXY=http://host.docker.internal:8000/v1/chat/completions +OPENAI_REVERSE_PROXY=http://host.docker.internal:4000/v1/chat/completions ``` #### 3. Save fake OpenAI key in Librechat's `.env` @@ -306,7 +306,7 @@ In the [config.py](https://continue.dev/docs/reference/Models/openai) set this a api_key="IGNORED", model="fake-model-name", context_length=2048, # customize if needed for your model - api_base="http://localhost:8000" # your proxy server url + api_base="http://localhost:4000" # your proxy server url ), ``` @@ -318,7 +318,7 @@ Credits [@vividfog](https://github.com/jmorganca/ollama/issues/305#issuecomment- ```shell $ pip install aider -$ aider --openai-api-base http://0.0.0.0:8000 --openai-api-key fake-key +$ aider --openai-api-base http://0.0.0.0:4000 --openai-api-key fake-key ``` @@ -332,7 +332,7 @@ from autogen import AssistantAgent, UserProxyAgent, oai config_list=[ { "model": "my-fake-model", - "api_base": "http://localhost:8000", #litellm compatible endpoint + "api_base": "http://localhost:4000", #litellm compatible endpoint "api_type": "open_ai", "api_key": "NULL", # just a placeholder } @@ -370,7 +370,7 @@ import guidance # set api_base to your proxy # set api_key to anything -gpt4 = guidance.llms.OpenAI("gpt-4", api_base="http://0.0.0.0:8000", api_key="anything") +gpt4 = guidance.llms.OpenAI("gpt-4", api_base="http://0.0.0.0:4000", api_key="anything") experts = guidance(''' {{#system~}} @@ -479,7 +479,7 @@ $ litellm --config /path/to/config.yaml #### Step 3: Use proxy Curl Command ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "zephyr-alpha", @@ -529,7 +529,7 @@ $ litellm --config /path/to/config.yaml #### Step 3: Use proxy Curl Command ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "gpt-3.5-turbo", @@ -586,7 +586,7 @@ litellm_settings: **Set dynamically** ```bash -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Content-Type: application/json' \ --data ' { "model": "zephyr-beta", @@ -615,7 +615,7 @@ model_list: - model_name: custom_embedding_model litellm_params: model: openai/custom_embedding # the `openai/` prefix tells litellm it's openai compatible - api_base: http://0.0.0.0:8000/ + api_base: http://0.0.0.0:4000/ - model_name: custom_embedding_model litellm_params: model: openai/custom_embedding # the `openai/` prefix tells litellm it's openai compatible @@ -665,7 +665,7 @@ litellm --config /path/to/config.yaml **Step 3: Generate temporary keys** ```shell -curl 'http://0.0.0.0:8000/key/generate' \ +curl 'http://0.0.0.0:4000/key/generate' \ --h 'Authorization: Bearer sk-1234' \ --d '{"models": ["gpt-3.5-turbo", "gpt-4", "claude-2"], "duration": "20m"}' ``` @@ -719,7 +719,7 @@ model_list: **Step 2: Generate a user key - enabling them access to specific models, custom model aliases, etc.** ```bash -curl -X POST "https://0.0.0.0:8000/key/generate" \ +curl -X POST "https://0.0.0.0:4000/key/generate" \ -H "Authorization: Bearer sk-1234" \ -H "Content-Type: application/json" \ -d '{ @@ -737,7 +737,7 @@ curl -X POST "https://0.0.0.0:8000/key/generate" \ You can get spend for a key by using the `/key/info` endpoint. ```bash -curl 'http://0.0.0.0:8000/key/info?key=' \ +curl 'http://0.0.0.0:4000/key/info?key=' \ -X GET \ -H 'Authorization: Bearer ' ``` @@ -868,7 +868,7 @@ $ litellm --config /path/to/config.yaml #### Using Caching Send the same request twice: ```shell -curl http://0.0.0.0:8000/v1/chat/completions \ +curl http://0.0.0.0:4000/v1/chat/completions \ -H "Content-Type: application/json" \ -d '{ "model": "gpt-3.5-turbo", @@ -876,7 +876,7 @@ curl http://0.0.0.0:8000/v1/chat/completions \ "temperature": 0.7 }' -curl http://0.0.0.0:8000/v1/chat/completions \ +curl http://0.0.0.0:4000/v1/chat/completions \ -H "Content-Type: application/json" \ -d '{ "model": "gpt-3.5-turbo", @@ -889,7 +889,7 @@ curl http://0.0.0.0:8000/v1/chat/completions \ Caching can be switched on/off per `/chat/completions` request - Caching **on** for completion - pass `caching=True`: ```shell - curl http://0.0.0.0:8000/v1/chat/completions \ + curl http://0.0.0.0:4000/v1/chat/completions \ -H "Content-Type: application/json" \ -d '{ "model": "gpt-3.5-turbo", @@ -900,7 +900,7 @@ Caching can be switched on/off per `/chat/completions` request ``` - Caching **off** for completion - pass `caching=False`: ```shell - curl http://0.0.0.0:8000/v1/chat/completions \ + curl http://0.0.0.0:4000/v1/chat/completions \ -H "Content-Type: application/json" \ -d '{ "model": "gpt-3.5-turbo", @@ -963,10 +963,10 @@ https://api.openai.com/v1/chat/completions \ Use this to health check all LLMs defined in your config.yaml #### Request ```shell -curl --location 'http://0.0.0.0:8000/health' +curl --location 'http://0.0.0.0:4000/health' ``` -You can also run `litellm -health` it makes a `get` request to `http://0.0.0.0:8000/health` for you +You can also run `litellm -health` it makes a `get` request to `http://0.0.0.0:4000/health` for you ``` litellm --health ``` @@ -1087,7 +1087,7 @@ litellm -config config.yaml #### Run a test request to Proxy ```shell -curl --location 'http://0.0.0.0:8000/chat/completions' \ +curl --location 'http://0.0.0.0:4000/chat/completions' \ --header 'Authorization: Bearer sk-1244' \ --data ' { "model": "gpt-3.5-turbo", @@ -1213,7 +1213,7 @@ LiteLLM proxy adds **0.00325 seconds** latency as compared to using the Raw Open ``` #### --port - - **Default:** `8000` + - **Default:** `4000` - The port to bind the server to. - **Usage:** ```shell diff --git a/litellm/proxy/proxy_cli.py b/litellm/proxy/proxy_cli.py index 367bbbb70..e5bcff646 100644 --- a/litellm/proxy/proxy_cli.py +++ b/litellm/proxy/proxy_cli.py @@ -61,7 +61,7 @@ def is_port_in_use(port): @click.option( "--host", default="0.0.0.0", help="Host for the server to listen on.", envvar="HOST" ) -@click.option("--port", default=8000, help="Port to bind the server to.", envvar="PORT") +@click.option("--port", default=4000, help="Port to bind the server to.", envvar="PORT") @click.option( "--num_workers", default=default_num_workers, @@ -273,7 +273,7 @@ def run_server( ], } - response = requests.post("http://0.0.0.0:8000/queue/request", json=data) + response = requests.post("http://0.0.0.0:4000/queue/request", json=data) response = response.json() @@ -507,7 +507,7 @@ def run_server( print( f"Unable to connect to DB. DATABASE_URL found in environment, but prisma package not found." ) - if port == 8000 and is_port_in_use(port): + if port == 4000 and is_port_in_use(port): port = random.randint(1024, 49152) from litellm.proxy.proxy_server import app diff --git a/litellm/router.py b/litellm/router.py index d4c0be862..2827a307c 100644 --- a/litellm/router.py +++ b/litellm/router.py @@ -246,7 +246,7 @@ class Router: "122999-2828282-277: { "model": "gpt-3", - "api_base": "http://localhost:8000", + "api_base": "http://localhost:4000", "num_requests": 20, "avg_latency": 0.001, "num_failures": 0, From eb531364486ebce736eb2c2150d5b0b110eff134 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Fri, 8 Mar 2024 22:05:39 -0800 Subject: [PATCH 50/74] (ci/cd) run again --- litellm/tests/test_streaming.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/litellm/tests/test_streaming.py b/litellm/tests/test_streaming.py index c513447b0..2896b4a71 100644 --- a/litellm/tests/test_streaming.py +++ b/litellm/tests/test_streaming.py @@ -511,7 +511,7 @@ def test_completion_mistral_api_stream(): def test_completion_deep_infra_stream(): - # deep infra currently includes role in the 2nd chunk + # deep infra,currently includes role in the 2nd chunk # waiting for them to make a fix on this litellm.set_verbose = True try: From fac01f8481ecdcbd672de05c564ad898bb6763fe Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 22:23:21 -0800 Subject: [PATCH 51/74] fix(azure.py): add pre call logging for transcription calls --- litellm/llms/azure.py | 29 +++++++++++++++++++++++++++++ litellm/utils.py | 1 + tests/test_whisper.py | 3 +++ 3 files changed, 33 insertions(+) diff --git a/litellm/llms/azure.py b/litellm/llms/azure.py index e19023b03..fb0d8b621 100644 --- a/litellm/llms/azure.py +++ b/litellm/llms/azure.py @@ -15,6 +15,7 @@ import litellm, json import httpx from .custom_httpx.azure_dall_e_2 import CustomHTTPTransport, AsyncCustomHTTPTransport from openai import AzureOpenAI, AsyncAzureOpenAI +import uuid class AzureOpenAIError(Exception): @@ -809,6 +810,19 @@ class AzureChatCompletion(BaseLLM): azure_client = AzureOpenAI(http_client=litellm.client_session, **azure_client_params) # type: ignore else: azure_client = client + + ## LOGGING + logging_obj.pre_call( + input=f"audio_file_{uuid.uuid4()}", + api_key=azure_client.api_key, + additional_args={ + "headers": {"Authorization": f"Bearer {azure_client.api_key}"}, + "api_base": azure_client._base_url._uri_reference, + "atranscription": True, + "complete_input_dict": data, + }, + ) + response = azure_client.audio.transcriptions.create( **data, timeout=timeout # type: ignore ) @@ -845,6 +859,21 @@ class AzureChatCompletion(BaseLLM): ) else: async_azure_client = client + + ## LOGGING + logging_obj.pre_call( + input=f"audio_file_{uuid.uuid4()}", + api_key=async_azure_client.api_key, + additional_args={ + "headers": { + "Authorization": f"Bearer {async_azure_client.api_key}" + }, + "api_base": async_azure_client._base_url._uri_reference, + "atranscription": True, + "complete_input_dict": data, + }, + ) + response = await async_azure_client.audio.transcriptions.create( **data, timeout=timeout ) # type: ignore diff --git a/litellm/utils.py b/litellm/utils.py index 330903f5a..c8a03245a 100644 --- a/litellm/utils.py +++ b/litellm/utils.py @@ -981,6 +981,7 @@ class Logging: curl_command = self.model_call_details # only print verbose if verbose logger is not set + if verbose_logger.level == 0: # this means verbose logger was not switched on - user is in litellm.set_verbose=True print_verbose(f"\033[92m{curl_command}\033[0m\n") diff --git a/tests/test_whisper.py b/tests/test_whisper.py index 78e885ad3..7b6a4aa01 100644 --- a/tests/test_whisper.py +++ b/tests/test_whisper.py @@ -35,6 +35,7 @@ def test_transcription(): def test_transcription_azure(): + litellm.set_verbose = True transcript = litellm.transcription( model="azure/azure-whisper", file=audio_file, @@ -46,6 +47,8 @@ def test_transcription_azure(): assert transcript.text is not None assert isinstance(transcript.text, str) + raise Exception("it worked") + # test_transcription_azure() From 5f15047a03c97192d95dd261dad0cbd66f614664 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 22:27:36 -0800 Subject: [PATCH 52/74] build(config.yml): test specific whisper endpoint --- .circleci/config.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index daa4d59ec..1fd19905c 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -182,7 +182,7 @@ jobs: command: | pwd ls - python -m pytest -vv tests/ -x --junitxml=test-results/junit.xml --durations=5 + python -m pytest -vv tests/test_whisper.py -x --junitxml=test-results/junit.xml --durations=5 no_output_timeout: 120m # Store test results From 0432c85bf79b53e6f85d26a94610bd0a90fdbcf9 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 22:43:07 -0800 Subject: [PATCH 53/74] test(test_whisper.py): add debugging for circle ci error --- tests/test_whisper.py | 1 + 1 file changed, 1 insertion(+) diff --git a/tests/test_whisper.py b/tests/test_whisper.py index 7b6a4aa01..b409a8f33 100644 --- a/tests/test_whisper.py +++ b/tests/test_whisper.py @@ -36,6 +36,7 @@ def test_transcription(): def test_transcription_azure(): litellm.set_verbose = True + print(f"AZURE EUROPE API BASE: {os.getenv('AZURE_EUROPE_API_BASE', None)}") transcript = litellm.transcription( model="azure/azure-whisper", file=audio_file, From c0c76707a1b14deb3f3b517807965dc732ad29ca Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 22:44:22 -0800 Subject: [PATCH 54/74] test(test_whisper.py): cleanup test --- tests/test_whisper.py | 2 -- 1 file changed, 2 deletions(-) diff --git a/tests/test_whisper.py b/tests/test_whisper.py index b409a8f33..62e50392c 100644 --- a/tests/test_whisper.py +++ b/tests/test_whisper.py @@ -48,8 +48,6 @@ def test_transcription_azure(): assert transcript.text is not None assert isinstance(transcript.text, str) - raise Exception("it worked") - # test_transcription_azure() From 7ff8fa09d614d61e71265941e2940a00769f3b1c Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 22:51:17 -0800 Subject: [PATCH 55/74] test(test_whisper.py): hardcode api base --- tests/test_whisper.py | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/tests/test_whisper.py b/tests/test_whisper.py index 62e50392c..dfeebb161 100644 --- a/tests/test_whisper.py +++ b/tests/test_whisper.py @@ -36,13 +36,12 @@ def test_transcription(): def test_transcription_azure(): litellm.set_verbose = True - print(f"AZURE EUROPE API BASE: {os.getenv('AZURE_EUROPE_API_BASE', None)}") transcript = litellm.transcription( model="azure/azure-whisper", file=audio_file, - api_base=os.getenv("AZURE_EUROPE_API_BASE"), + api_base="https://my-endpoint-europe-berri-992.openai.azure.com/", api_key=os.getenv("AZURE_EUROPE_API_KEY"), - api_version=os.getenv("2024-02-15-preview"), + api_version="2024-02-15-preview", ) assert transcript.text is not None @@ -57,9 +56,9 @@ async def test_transcription_async_azure(): transcript = await litellm.atranscription( model="azure/azure-whisper", file=audio_file, - api_base=os.getenv("AZURE_EUROPE_API_BASE"), + api_base="https://my-endpoint-europe-berri-992.openai.azure.com/", api_key=os.getenv("AZURE_EUROPE_API_KEY"), - api_version=os.getenv("2024-02-15-preview"), + api_version="2024-02-15-preview", ) assert transcript.text is not None From daa371ade900a93b5b6abe0cc16d6c1e37ba01e8 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 22:41:32 -0800 Subject: [PATCH 56/74] fix(utils.py): add support for anthropic params in get_supported_openai_params --- litellm/__init__.py | 2 +- litellm/utils.py | 16 ++++++++++++++-- 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/litellm/__init__.py b/litellm/__init__.py index 506147166..04c2d23c7 100644 --- a/litellm/__init__.py +++ b/litellm/__init__.py @@ -570,7 +570,7 @@ from .utils import ( _calculate_retry_after, _should_retry, get_secret, - get_mapped_model_params, + get_supported_openai_params, ) from .llms.huggingface_restapi import HuggingfaceConfig from .llms.anthropic import AnthropicConfig diff --git a/litellm/utils.py b/litellm/utils.py index 32f0f765b..83f2a7ec1 100644 --- a/litellm/utils.py +++ b/litellm/utils.py @@ -4581,7 +4581,7 @@ def get_optional_params( if stream: optional_params["stream"] = stream elif "anthropic" in model: - supported_params = get_mapped_model_params( + supported_params = get_supported_openai_params( model=model, custom_llm_provider=custom_llm_provider ) _check_valid_arg(supported_params=supported_params) @@ -5048,7 +5048,7 @@ def get_optional_params( return optional_params -def get_mapped_model_params(model: str, custom_llm_provider: str): +def get_supported_openai_params(model: str, custom_llm_provider: str): """ Returns the supported openai params for a given model + provider """ @@ -5057,6 +5057,18 @@ def get_mapped_model_params(model: str, custom_llm_provider: str): return litellm.AmazonAnthropicClaude3Config().get_supported_openai_params() else: return litellm.AmazonAnthropicConfig().get_supported_openai_params() + elif custom_llm_provider == "ollama_chat": + return litellm.OllamaChatConfig().get_supported_openai_params() + elif custom_llm_provider == "anthropic": + return [ + "stream", + "stop", + "temperature", + "top_p", + "max_tokens", + "tools", + "tool_choice", + ] def get_llm_provider( From aeb3cbc9b6f9e53a79b44b9e43c68493b672652c Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 22:49:24 -0800 Subject: [PATCH 57/74] fix(utils.py): add additional providers to get_supported_openai_params --- litellm/utils.py | 146 +++++++++++++++++++++++++++-------------------- 1 file changed, 85 insertions(+), 61 deletions(-) diff --git a/litellm/utils.py b/litellm/utils.py index 83f2a7ec1..3d80ddf58 100644 --- a/litellm/utils.py +++ b/litellm/utils.py @@ -4254,15 +4254,9 @@ def get_optional_params( ## raise exception if provider doesn't support passed in param if custom_llm_provider == "anthropic": ## check if unsupported param passed in - supported_params = [ - "stream", - "stop", - "temperature", - "top_p", - "max_tokens", - "tools", - "tool_choice", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) # handle anthropic params if stream: @@ -4286,17 +4280,9 @@ def get_optional_params( optional_params["tools"] = tools elif custom_llm_provider == "cohere": ## check if unsupported param passed in - supported_params = [ - "stream", - "temperature", - "max_tokens", - "logit_bias", - "top_p", - "frequency_penalty", - "presence_penalty", - "stop", - "n", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) # handle cohere params if stream: @@ -4897,25 +4883,9 @@ def get_optional_params( extra_body # openai client supports `extra_body` param ) elif custom_llm_provider == "openrouter": - supported_params = [ - "functions", - "function_call", - "temperature", - "top_p", - "n", - "stream", - "stop", - "max_tokens", - "presence_penalty", - "frequency_penalty", - "logit_bias", - "user", - "response_format", - "seed", - "tools", - "tool_choice", - "max_retries", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if functions is not None: @@ -4969,28 +4939,9 @@ def get_optional_params( ) else: # assume passing in params for openai/azure openai print_verbose(f"UNMAPPED PROVIDER, ASSUMING IT'S OPENAI/AZURE") - supported_params = [ - "functions", - "function_call", - "temperature", - "top_p", - "n", - "stream", - "stop", - "max_tokens", - "presence_penalty", - "frequency_penalty", - "logit_bias", - "user", - "response_format", - "seed", - "tools", - "tool_choice", - "max_retries", - "logprobs", - "top_logprobs", - "extra_headers", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider="openai" + ) _check_valid_arg(supported_params=supported_params) if functions is not None: optional_params["functions"] = functions @@ -5069,6 +5020,79 @@ def get_supported_openai_params(model: str, custom_llm_provider: str): "tools", "tool_choice", ] + elif custom_llm_provider == "cohere": + return [ + "stream", + "temperature", + "max_tokens", + "logit_bias", + "top_p", + "frequency_penalty", + "presence_penalty", + "stop", + "n", + ] + elif custom_llm_provider == "maritalk": + return [ + "stream", + "temperature", + "max_tokens", + "top_p", + "presence_penalty", + "stop", + ] + elif custom_llm_provider == "openai" or custom_llm_provider == "azure": + return [ + "functions", + "function_call", + "temperature", + "top_p", + "n", + "stream", + "stop", + "max_tokens", + "presence_penalty", + "frequency_penalty", + "logit_bias", + "user", + "response_format", + "seed", + "tools", + "tool_choice", + "max_retries", + "logprobs", + "top_logprobs", + "extra_headers", + ] + elif custom_llm_provider == "openrouter": + return [ + "functions", + "function_call", + "temperature", + "top_p", + "n", + "stream", + "stop", + "max_tokens", + "presence_penalty", + "frequency_penalty", + "logit_bias", + "user", + "response_format", + "seed", + "tools", + "tool_choice", + "max_retries", + ] + elif custom_llm_provider == "mistral": + return [ + "temperature", + "top_p", + "stream", + "max_tokens", + "tools", + "tool_choice", + ] def get_llm_provider( From fd52b502a63ab34c5ca9dfe5e5c116bba54f3305 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 23:06:26 -0800 Subject: [PATCH 58/74] fix(utils.py): *new* get_supported_openai_params() function Returns the supported openai params for a given model + provider --- litellm/utils.py | 293 +++++++++++++++++++++++++++++------------------ 1 file changed, 180 insertions(+), 113 deletions(-) diff --git a/litellm/utils.py b/litellm/utils.py index 3d80ddf58..44921f72e 100644 --- a/litellm/utils.py +++ b/litellm/utils.py @@ -4305,14 +4305,9 @@ def get_optional_params( optional_params["stop_sequences"] = stop elif custom_llm_provider == "maritalk": ## check if unsupported param passed in - supported_params = [ - "stream", - "temperature", - "max_tokens", - "top_p", - "presence_penalty", - "stop", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) # handle cohere params if stream: @@ -4331,14 +4326,9 @@ def get_optional_params( optional_params["stopping_tokens"] = stop elif custom_llm_provider == "replicate": ## check if unsupported param passed in - supported_params = [ - "stream", - "temperature", - "max_tokens", - "top_p", - "stop", - "seed", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if stream: @@ -4359,7 +4349,9 @@ def get_optional_params( optional_params["stop_sequences"] = stop elif custom_llm_provider == "huggingface": ## check if unsupported param passed in - supported_params = ["stream", "temperature", "max_tokens", "top_p", "stop", "n"] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) # temperature, top_p, n, stream, stop, max_tokens, n, presence_penalty default to None if temperature is not None: @@ -4398,16 +4390,9 @@ def get_optional_params( ) # since we handle translating echo, we should not send it to TGI request elif custom_llm_provider == "together_ai": ## check if unsupported param passed in - supported_params = [ - "stream", - "temperature", - "max_tokens", - "top_p", - "stop", - "frequency_penalty", - "tools", - "tool_choice", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if stream: @@ -4428,16 +4413,9 @@ def get_optional_params( optional_params["tool_choice"] = tool_choice elif custom_llm_provider == "ai21": ## check if unsupported param passed in - supported_params = [ - "stream", - "n", - "temperature", - "max_tokens", - "top_p", - "stop", - "frequency_penalty", - "presence_penalty", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if stream: @@ -4460,7 +4438,9 @@ def get_optional_params( custom_llm_provider == "palm" or custom_llm_provider == "gemini" ): # https://developers.generativeai.google/tutorials/curl_quickstart ## check if unsupported param passed in - supported_params = ["temperature", "top_p", "stream", "n", "stop", "max_tokens"] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if temperature is not None: @@ -4489,14 +4469,9 @@ def get_optional_params( ): print_verbose(f"(start) INSIDE THE VERTEX AI OPTIONAL PARAM BLOCK") ## check if unsupported param passed in - supported_params = [ - "temperature", - "top_p", - "max_tokens", - "stream", - "tools", - "tool_choice", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if temperature is not None: @@ -4526,7 +4501,9 @@ def get_optional_params( ) elif custom_llm_provider == "sagemaker": ## check if unsupported param passed in - supported_params = ["stream", "temperature", "max_tokens", "top_p", "stop", "n"] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) # temperature, top_p, n, stream, stop, max_tokens, n, presence_penalty default to None if temperature is not None: @@ -4553,8 +4530,10 @@ def get_optional_params( max_tokens = 1 optional_params["max_new_tokens"] = max_tokens elif custom_llm_provider == "bedrock": + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) if "ai21" in model: - supported_params = ["max_tokens", "temperature", "top_p", "stream"] _check_valid_arg(supported_params=supported_params) # params "maxTokens":200,"temperature":0,"topP":250,"stop_sequences":[], # https://us-west-2.console.aws.amazon.com/bedrock/home?region=us-west-2#/providers?model=j2-ultra @@ -4567,9 +4546,6 @@ def get_optional_params( if stream: optional_params["stream"] = stream elif "anthropic" in model: - supported_params = get_supported_openai_params( - model=model, custom_llm_provider=custom_llm_provider - ) _check_valid_arg(supported_params=supported_params) # anthropic params on bedrock # \"max_tokens_to_sample\":300,\"temperature\":0.5,\"top_p\":1,\"stop_sequences\":[\"\\\\n\\\\nHuman:\"]}" @@ -4586,7 +4562,6 @@ def get_optional_params( optional_params=optional_params, ) elif "amazon" in model: # amazon titan llms - supported_params = ["max_tokens", "temperature", "stop", "top_p", "stream"] _check_valid_arg(supported_params=supported_params) # see https://us-west-2.console.aws.amazon.com/bedrock/home?region=us-west-2#/providers?model=titan-large if max_tokens is not None: @@ -4603,7 +4578,6 @@ def get_optional_params( if stream: optional_params["stream"] = stream elif "meta" in model: # amazon / meta llms - supported_params = ["max_tokens", "temperature", "top_p", "stream"] _check_valid_arg(supported_params=supported_params) # see https://us-west-2.console.aws.amazon.com/bedrock/home?region=us-west-2#/providers?model=titan-large if max_tokens is not None: @@ -4615,7 +4589,6 @@ def get_optional_params( if stream: optional_params["stream"] = stream elif "cohere" in model: # cohere models on bedrock - supported_params = ["stream", "temperature", "max_tokens"] _check_valid_arg(supported_params=supported_params) # handle cohere params if stream: @@ -4625,7 +4598,6 @@ def get_optional_params( if max_tokens is not None: optional_params["max_tokens"] = max_tokens elif "mistral" in model: - supported_params = ["max_tokens", "temperature", "stop", "top_p", "stream"] _check_valid_arg(supported_params=supported_params) # mistral params on bedrock # \"max_tokens\":400,\"temperature\":0.7,\"top_p\":0.7,\"stop\":[\"\\\\n\\\\nHuman:\"]}" @@ -4669,7 +4641,9 @@ def get_optional_params( optional_params["stop_sequences"] = stop elif custom_llm_provider == "cloudflare": # https://developers.cloudflare.com/workers-ai/models/text-generation/#input - supported_params = ["max_tokens", "stream"] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if max_tokens is not None: @@ -4677,14 +4651,9 @@ def get_optional_params( if stream is not None: optional_params["stream"] = stream elif custom_llm_provider == "ollama": - supported_params = [ - "max_tokens", - "stream", - "top_p", - "temperature", - "frequency_penalty", - "stop", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if max_tokens is not None: @@ -4708,16 +4677,9 @@ def get_optional_params( non_default_params=non_default_params, optional_params=optional_params ) elif custom_llm_provider == "nlp_cloud": - supported_params = [ - "max_tokens", - "stream", - "temperature", - "top_p", - "presence_penalty", - "frequency_penalty", - "n", - "stop", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if max_tokens is not None: @@ -4737,7 +4699,9 @@ def get_optional_params( if stop is not None: optional_params["stop_sequences"] = stop elif custom_llm_provider == "petals": - supported_params = ["max_tokens", "temperature", "top_p", "stream"] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) # max_new_tokens=1,temperature=0.9, top_p=0.6 if max_tokens is not None: @@ -4749,18 +4713,9 @@ def get_optional_params( if stream: optional_params["stream"] = stream elif custom_llm_provider == "deepinfra": - supported_params = [ - "temperature", - "top_p", - "n", - "stream", - "stop", - "max_tokens", - "presence_penalty", - "frequency_penalty", - "logit_bias", - "user", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if temperature is not None: if ( @@ -4787,14 +4742,9 @@ def get_optional_params( if user: optional_params["user"] = user elif custom_llm_provider == "perplexity": - supported_params = [ - "temperature", - "top_p", - "stream", - "max_tokens", - "presence_penalty", - "frequency_penalty", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if temperature is not None: if ( @@ -4813,15 +4763,9 @@ def get_optional_params( if frequency_penalty: optional_params["frequency_penalty"] = frequency_penalty elif custom_llm_provider == "anyscale": - supported_params = [ - "temperature", - "top_p", - "stream", - "max_tokens", - "stop", - "frequency_penalty", - "presence_penalty", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) if model in [ "mistralai/Mistral-7B-Instruct-v0.1", "mistralai/Mixtral-8x7B-Instruct-v0.1", @@ -4849,14 +4793,9 @@ def get_optional_params( if max_tokens: optional_params["max_tokens"] = max_tokens elif custom_llm_provider == "mistral": - supported_params = [ - "temperature", - "top_p", - "stream", - "max_tokens", - "tools", - "tool_choice", - ] + supported_params = get_supported_openai_params( + model=model, custom_llm_provider=custom_llm_provider + ) _check_valid_arg(supported_params=supported_params) if temperature is not None: optional_params["temperature"] = temperature @@ -5002,12 +4941,27 @@ def get_optional_params( def get_supported_openai_params(model: str, custom_llm_provider: str): """ Returns the supported openai params for a given model + provider + + Example: + ``` + get_supported_openai_params(model="anthropic.claude-3", custom_llm_provider="bedrock") + ``` """ if custom_llm_provider == "bedrock": if model.startswith("anthropic.claude-3"): return litellm.AmazonAnthropicClaude3Config().get_supported_openai_params() - else: + elif model.startswith("anthropic"): return litellm.AmazonAnthropicConfig().get_supported_openai_params() + elif model.startswith("ai21"): + return ["max_tokens", "temperature", "top_p", "stream"] + elif model.startswith("amazon"): + return ["max_tokens", "temperature", "stop", "top_p", "stream"] + elif model.startswith("meta"): + return ["max_tokens", "temperature", "top_p", "stream"] + elif model.startswith("cohere"): + return ["stream", "temperature", "max_tokens"] + elif model.startswith("mistral"): + return ["max_tokens", "temperature", "stop", "top_p", "stream"] elif custom_llm_provider == "ollama_chat": return litellm.OllamaChatConfig().get_supported_openai_params() elif custom_llm_provider == "anthropic": @@ -5093,6 +5047,119 @@ def get_supported_openai_params(model: str, custom_llm_provider: str): "tools", "tool_choice", ] + elif custom_llm_provider == "replicate": + return [ + "stream", + "temperature", + "max_tokens", + "top_p", + "stop", + "seed", + ] + elif custom_llm_provider == "huggingface": + return ["stream", "temperature", "max_tokens", "top_p", "stop", "n"] + elif custom_llm_provider == "together_ai": + return [ + "stream", + "temperature", + "max_tokens", + "top_p", + "stop", + "frequency_penalty", + "tools", + "tool_choice", + ] + elif custom_llm_provider == "ai21": + return [ + "stream", + "n", + "temperature", + "max_tokens", + "top_p", + "stop", + "frequency_penalty", + "presence_penalty", + ] + elif custom_llm_provider == "palm" or custom_llm_provider == "gemini": + return ["temperature", "top_p", "stream", "n", "stop", "max_tokens"] + elif custom_llm_provider == "vertex_ai": + return [ + "temperature", + "top_p", + "max_tokens", + "stream", + "tools", + "tool_choice", + ] + elif custom_llm_provider == "sagemaker": + return ["stream", "temperature", "max_tokens", "top_p", "stop", "n"] + elif custom_llm_provider == "aleph_alpha": + return [ + "max_tokens", + "stream", + "top_p", + "temperature", + "presence_penalty", + "frequency_penalty", + "n", + "stop", + ] + elif custom_llm_provider == "cloudflare": + return ["max_tokens", "stream"] + elif custom_llm_provider == "ollama": + return [ + "max_tokens", + "stream", + "top_p", + "temperature", + "frequency_penalty", + "stop", + ] + elif custom_llm_provider == "nlp_cloud": + return [ + "max_tokens", + "stream", + "temperature", + "top_p", + "presence_penalty", + "frequency_penalty", + "n", + "stop", + ] + elif custom_llm_provider == "petals": + return ["max_tokens", "temperature", "top_p", "stream"] + elif custom_llm_provider == "deepinfra": + return [ + "temperature", + "top_p", + "n", + "stream", + "stop", + "max_tokens", + "presence_penalty", + "frequency_penalty", + "logit_bias", + "user", + ] + elif custom_llm_provider == "perplexity": + return [ + "temperature", + "top_p", + "stream", + "max_tokens", + "presence_penalty", + "frequency_penalty", + ] + elif custom_llm_provider == "anyscale": + return [ + "temperature", + "top_p", + "stream", + "max_tokens", + "stop", + "frequency_penalty", + "presence_penalty", + ] def get_llm_provider( From c15c05e46038cef1359bc804cdc598d6edcfa7bd Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 23:07:26 -0800 Subject: [PATCH 59/74] build(config.yml): fix config.yml --- .circleci/config.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.circleci/config.yml b/.circleci/config.yml index 1fd19905c..daa4d59ec 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -182,7 +182,7 @@ jobs: command: | pwd ls - python -m pytest -vv tests/test_whisper.py -x --junitxml=test-results/junit.xml --durations=5 + python -m pytest -vv tests/ -x --junitxml=test-results/junit.xml --durations=5 no_output_timeout: 120m # Store test results From fef47618a7ba5996a8bb3ecf9a01bb525ed07870 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 23:31:18 -0800 Subject: [PATCH 60/74] =?UTF-8?q?bump:=20version=201.30.4=20=E2=86=92=201.?= =?UTF-8?q?30.5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- pyproject.toml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 4c00be910..9808352d6 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "litellm" -version = "1.30.4" +version = "1.30.5" description = "Library to easily interface with LLM API providers" authors = ["BerriAI"] license = "MIT" @@ -74,7 +74,7 @@ requires = ["poetry-core", "wheel"] build-backend = "poetry.core.masonry.api" [tool.commitizen] -version = "1.30.4" +version = "1.30.5" version_files = [ "pyproject.toml:^version" ] From 775997b283e34d3bbeb628d801d3e03741de5175 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 23:33:54 -0800 Subject: [PATCH 61/74] fix(openai.py): fix async audio transcription --- litellm/llms/openai.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/litellm/llms/openai.py b/litellm/llms/openai.py index 64c0aa3af..9850cd61e 100644 --- a/litellm/llms/openai.py +++ b/litellm/llms/openai.py @@ -862,7 +862,7 @@ class OpenAIChatCompletion(BaseLLM): additional_args={"complete_input_dict": data}, original_response=stringified_response, ) - return convert_to_model_response_object(response_object=stringified_response, model_response_object=model_response, response_type="image_generation") # type: ignore + return convert_to_model_response_object(response_object=stringified_response, model_response_object=model_response, response_type="audio_transcription") # type: ignore except Exception as e: ## LOGGING logging_obj.post_call( From b0fa25dfbda17a02df36a47b2236612424a22876 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 23:51:24 -0800 Subject: [PATCH 62/74] docs(audio_transcription.md): add docs on audio transcription --- docs/my-website/docs/audio_transcription.md | 85 +++++++++++++++++++++ docs/my-website/sidebars.js | 5 +- 2 files changed, 88 insertions(+), 2 deletions(-) create mode 100644 docs/my-website/docs/audio_transcription.md diff --git a/docs/my-website/docs/audio_transcription.md b/docs/my-website/docs/audio_transcription.md new file mode 100644 index 000000000..09fa1a1b9 --- /dev/null +++ b/docs/my-website/docs/audio_transcription.md @@ -0,0 +1,85 @@ +import Tabs from '@theme/Tabs'; +import TabItem from '@theme/TabItem'; + +# Audio Transcription + +Use this to loadbalance across Azure + OpenAI. + +## Quick Start + +```python +from litellm import transcription +import os + +# set api keys +os.environ["OPENAI_API_KEY"] = "" +audio_file = open("/path/to/audio.mp3", "rb") + +response = transcription(model="whisper", file=audio_file) + +print(f"response: {response}") +``` + +## Proxy Usage + +### Add model to config + + + + + +```yaml +model_list: +- model_name: whisper + litellm_params: + model: whisper-1 + api_key: os.environ/OPENAI_API_KEY + model_info: + mode: audio_transcription + +general_settings: + master_key: sk-1234 +``` + + + +```yaml +model_list: +- model_name: whisper + litellm_params: + model: whisper-1 + api_key: os.environ/OPENAI_API_KEY + model_info: + mode: audio_transcription +- model_name: whisper + litellm_params: + model: azure/azure-whisper + api_version: 2024-02-15-preview + api_base: os.environ/AZURE_EUROPE_API_BASE + api_key: os.environ/AZURE_EUROPE_API_KEY + model_info: + mode: audio_transcription + +general_settings: + master_key: sk-1234 +``` + + + + +### Start proxy + +```bash +litellm --config /path/to/config.yaml + +# RUNNING on http://0.0.0.0:8000 +``` + +### Test + +```bash +curl --location 'http://0.0.0.0:4000/v1/audio/transcriptions' \ +--header 'Authorization: Bearer sk-1234' \ +--form 'file=@"/Users/krrishdholakia/Downloads/gettysburg.wav"' \ +--form 'model="whisper"' +``` diff --git a/docs/my-website/sidebars.js b/docs/my-website/sidebars.js index 7aaf2e114..33720b43e 100644 --- a/docs/my-website/sidebars.js +++ b/docs/my-website/sidebars.js @@ -101,12 +101,13 @@ const sidebars = { }, { type: "category", - label: "Embedding(), Moderation(), Image Generation()", + label: "Embedding(), Moderation(), Image Generation(), Audio Transcriptions()", items: [ "embedding/supported_embedding", "embedding/async_embedding", "embedding/moderation", - "image_generation" + "image_generation", + "audio_transcription" ], }, { From d8a6b8216d4f1992cf72c98122cfbfdbb6d4d5a8 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Fri, 8 Mar 2024 23:54:13 -0800 Subject: [PATCH 63/74] docs(input.md): add docs on 'get_supported_openai_params' --- docs/my-website/docs/completion/input.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/docs/my-website/docs/completion/input.md b/docs/my-website/docs/completion/input.md index e3ad9245d..fd5594610 100644 --- a/docs/my-website/docs/completion/input.md +++ b/docs/my-website/docs/completion/input.md @@ -24,6 +24,17 @@ print(response) ``` ### Translated OpenAI params + +Use this function to get an up-to-date list of supported openai params for any model + provider. + +```python +from litellm import get_supported_openai_params + +response = get_supported_openai_params(model="anthropic.claude-3", custom_llm_provider="bedrock") + +print(response) # ["max_tokens", "tools", "tool_choice", "stream"] +``` + This is a list of openai params we translate across providers. This list is constantly being updated. From 7a1b3ca30dc145f6604393e89e30c007e23e632d Mon Sep 17 00:00:00 2001 From: Debdut Chakraborty Date: Sun, 10 Mar 2024 01:52:36 +0530 Subject: [PATCH 64/74] feat(helm-chart): redis as cache managed by chart --- .gitignore | 1 + deploy/charts/litellm/Chart.yaml | 4 ++++ deploy/charts/litellm/templates/_helpers.tpl | 8 ++++++++ deploy/charts/litellm/templates/deployment.yaml | 11 +++++++++++ deploy/charts/litellm/values.yaml | 6 ++++++ 5 files changed, 30 insertions(+) diff --git a/.gitignore b/.gitignore index de1c7598f..b03bc895b 100644 --- a/.gitignore +++ b/.gitignore @@ -44,3 +44,4 @@ deploy/charts/litellm/*.tgz deploy/charts/litellm/charts/* deploy/charts/*.tgz litellm/proxy/vertex_key.json +**/.vim/ diff --git a/deploy/charts/litellm/Chart.yaml b/deploy/charts/litellm/Chart.yaml index 6ecdebb50..cc08a9921 100644 --- a/deploy/charts/litellm/Chart.yaml +++ b/deploy/charts/litellm/Chart.yaml @@ -31,3 +31,7 @@ dependencies: version: ">=13.3.0" repository: oci://registry-1.docker.io/bitnamicharts condition: db.deployStandalone + - name: redis + version: ">=18.0.0" + repository: oci://registry-1.docker.io/bitnamicharts + condition: redis.enabled diff --git a/deploy/charts/litellm/templates/_helpers.tpl b/deploy/charts/litellm/templates/_helpers.tpl index b8893d07c..fa563fadc 100644 --- a/deploy/charts/litellm/templates/_helpers.tpl +++ b/deploy/charts/litellm/templates/_helpers.tpl @@ -60,3 +60,11 @@ Create the name of the service account to use {{- default "default" .Values.serviceAccount.name }} {{- end }} {{- end }} + +{{/* +Get redis service name +*/}} +{{- define "litellm.redis.serviceName" -}} +{{- printf "%s-headless" (default "redis" .Values.redis.nameOverride | trunc 63 | trimSuffix "-") -}} +{{- end -}} + diff --git a/deploy/charts/litellm/templates/deployment.yaml b/deploy/charts/litellm/templates/deployment.yaml index 6ed112dac..bc2a0bd09 100644 --- a/deploy/charts/litellm/templates/deployment.yaml +++ b/deploy/charts/litellm/templates/deployment.yaml @@ -142,6 +142,17 @@ spec: secretKeyRef: name: {{ include "litellm.fullname" . }}-masterkey key: masterkey + {{- if .Values.redis.enabled }} + - name: REDIS_HOST + value: {{ template "litellm.redis.serviceName" . }} + - name: REDIS_PORT + value: {{ if .Values.redis.sentinel.enabled }}{{ .Values.redis.sentinel.service.ports.sentinel }}{{ else }}{{ .Values.redis.master.service.ports.redis}}{{ end }} + - name: REDIS_PASSWORD + valueFrom: + secretKeyRef: + name: {{ include "redis.secretName" . }} + key: {{include "redis.secretPasswordKey" . }} + {{- end }} envFrom: {{- range .Values.environmentSecrets }} - secretRef: diff --git a/deploy/charts/litellm/values.yaml b/deploy/charts/litellm/values.yaml index 1b83fe801..9b697b013 100644 --- a/deploy/charts/litellm/values.yaml +++ b/deploy/charts/litellm/values.yaml @@ -166,3 +166,9 @@ postgresql: # existingSecret: "" # secretKeys: # userPasswordKey: password + +# requires cache: true in config file +# either enable this or pass a secret for REDIS_HOST, REDIS_PORT, REDIS_PASSWORD or REDIS_URL +# with cache: true to use existing redis instance +redis: + enabled: false From 7ae7e95da174523ca56d4c932f32582f92faf10b Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Sat, 9 Mar 2024 13:04:52 -0800 Subject: [PATCH 65/74] (docs) litellm getting started clarify sdk vs proxy --- docs/my-website/docs/index.md | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/docs/my-website/docs/index.md b/docs/my-website/docs/index.md index d7ed14019..d3284e6fb 100644 --- a/docs/my-website/docs/index.md +++ b/docs/my-website/docs/index.md @@ -13,7 +13,14 @@ https://github.com/BerriAI/litellm - Retry/fallback logic across multiple deployments (e.g. Azure/OpenAI) - [Router](https://docs.litellm.ai/docs/routing) - Track spend & set budgets per project [OpenAI Proxy Server](https://docs.litellm.ai/docs/simple_proxy) -## Basic usage +## How to use LiteLLM +You can use litellm through either: +1. [OpenAI proxy Server](#openai-proxy) - Server to call 100+ LLMs, load balance, cost tracking across projects +2. [LiteLLM python SDK](#basic-usage) - Python Client to call 100+ LLMs, load balance, cost tracking + +## LiteLLM Python SDK + +### Basic usage Open In Colab @@ -144,7 +151,7 @@ response = completion( -## Streaming +### Streaming Set `stream=True` in the `completion` args. @@ -276,7 +283,7 @@ response = completion( -## Exception handling +### Exception handling LiteLLM maps exceptions across all supported providers to the OpenAI exceptions. All our exceptions inherit from OpenAI's exception types, so any error-handling you have for that, should work out of the box with LiteLLM. @@ -292,7 +299,7 @@ except OpenAIError as e: print(e) ``` -## Logging Observability - Log LLM Input/Output ([Docs](https://docs.litellm.ai/docs/observability/callbacks)) +### Logging Observability - Log LLM Input/Output ([Docs](https://docs.litellm.ai/docs/observability/callbacks)) LiteLLM exposes pre defined callbacks to send data to Langfuse, LLMonitor, Helicone, Promptlayer, Traceloop, Slack ```python from litellm import completion @@ -311,7 +318,7 @@ litellm.success_callback = ["langfuse", "llmonitor"] # log input/output to langf response = completion(model="gpt-3.5-turbo", messages=[{"role": "user", "content": "Hi 👋 - i'm openai"}]) ``` -## Track Costs, Usage, Latency for streaming +### Track Costs, Usage, Latency for streaming Use a callback function for this - more info on custom callbacks: https://docs.litellm.ai/docs/observability/custom_callback ```python From 4b60bea975b93a5caa4f1cbcb3c8cfe1c5190dfc Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Sat, 9 Mar 2024 13:05:01 -0800 Subject: [PATCH 66/74] fix(proxy/utils.py): add more logging for prisma client get_data error --- litellm/proxy/utils.py | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/litellm/proxy/utils.py b/litellm/proxy/utils.py index 32f799360..89976ff0d 100644 --- a/litellm/proxy/utils.py +++ b/litellm/proxy/utils.py @@ -761,6 +761,7 @@ class PrismaClient: int ] = None, # pagination, number of rows to getch when find_all==True ): + args_passed_in = locals() verbose_proxy_logger.debug( f"PrismaClient: get_data: token={token}, table_name: {table_name}, query_type: {query_type}, user_id: {user_id}, user_id_list: {user_id_list}, team_id: {team_id}, team_id_list: {team_id_list}, key_val: {key_val}" ) @@ -794,6 +795,12 @@ class PrismaClient: response.expires, datetime ): response.expires = response.expires.isoformat() + else: + # Token does not exist. + raise HTTPException( + status_code=status.HTTP_401_UNAUTHORIZED, + detail=f"Authentication Error: invalid user key - user key does not exist in db. User Key={token}", + ) elif query_type == "find_all" and user_id is not None: response = await self.db.litellm_verificationtoken.find_many( where={"user_id": user_id}, @@ -997,7 +1004,7 @@ class PrismaClient: except Exception as e: import traceback - prisma_query_info = f"LiteLLM Prisma Client Exception: get_data: token={token}, table_name: {table_name}, query_type: {query_type}, user_id: {user_id}, user_id_list: {user_id_list}, team_id: {team_id}, team_id_list: {team_id_list}, key_val: {key_val}" + prisma_query_info = f"LiteLLM Prisma Client Exception: Error with `get_data`. Args passed in: {args_passed_in}" error_msg = prisma_query_info + str(e) print_verbose(error_msg) error_traceback = error_msg + "\n" + traceback.format_exc() From 5692481515742fa7220f4ecd246227d516ac4f47 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Sat, 9 Mar 2024 13:06:37 -0800 Subject: [PATCH 67/74] =?UTF-8?q?bump:=20version=201.30.5=20=E2=86=92=201.?= =?UTF-8?q?30.6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- pyproject.toml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 9808352d6..fa7a78775 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "litellm" -version = "1.30.5" +version = "1.30.6" description = "Library to easily interface with LLM API providers" authors = ["BerriAI"] license = "MIT" @@ -74,7 +74,7 @@ requires = ["poetry-core", "wheel"] build-backend = "poetry.core.masonry.api" [tool.commitizen] -version = "1.30.5" +version = "1.30.6" version_files = [ "pyproject.toml:^version" ] From b3646f6644efaa6dc8ec851e035069833797f954 Mon Sep 17 00:00:00 2001 From: Debdut Chakraborty Date: Sun, 10 Mar 2024 02:37:10 +0530 Subject: [PATCH 68/74] fix: redis context --- deploy/charts/litellm/Chart.lock | 9 ++++++--- deploy/charts/litellm/templates/deployment.yaml | 4 ++-- 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/deploy/charts/litellm/Chart.lock b/deploy/charts/litellm/Chart.lock index 7b6ed69d9..f13578d8d 100644 --- a/deploy/charts/litellm/Chart.lock +++ b/deploy/charts/litellm/Chart.lock @@ -1,6 +1,9 @@ dependencies: - name: postgresql repository: oci://registry-1.docker.io/bitnamicharts - version: 13.3.1 -digest: sha256:f5c129150f0d38dd06752ab37f3c8e143d7c14d30379af058767bcd9f4ba83dd -generated: "2024-01-19T11:32:56.694808861+11:00" + version: 14.3.1 +- name: redis + repository: oci://registry-1.docker.io/bitnamicharts + version: 18.19.1 +digest: sha256:8660fe6287f9941d08c0902f3f13731079b8cecd2a5da2fbc54e5b7aae4a6f62 +generated: "2024-03-10T02:28:52.275022+05:30" diff --git a/deploy/charts/litellm/templates/deployment.yaml b/deploy/charts/litellm/templates/deployment.yaml index bc2a0bd09..42cf84935 100644 --- a/deploy/charts/litellm/templates/deployment.yaml +++ b/deploy/charts/litellm/templates/deployment.yaml @@ -150,8 +150,8 @@ spec: - name: REDIS_PASSWORD valueFrom: secretKeyRef: - name: {{ include "redis.secretName" . }} - key: {{include "redis.secretPasswordKey" . }} + name: {{ include "redis.secretName" .Subcharts.redis }} + key: {{include "redis.secretPasswordKey" .Subcharts.redis }} {{- end }} envFrom: {{- range .Values.environmentSecrets }} From eea803cae44ab34a90075042f468b09512fe1014 Mon Sep 17 00:00:00 2001 From: Debdut Chakraborty Date: Sun, 10 Mar 2024 03:06:17 +0530 Subject: [PATCH 69/74] chore: better handling redis deployment architecture and connection --- deploy/charts/litellm/templates/_helpers.tpl | 16 +++++++++++++++- deploy/charts/litellm/templates/deployment.yaml | 4 ++-- deploy/charts/litellm/values.yaml | 3 +++ 3 files changed, 20 insertions(+), 3 deletions(-) diff --git a/deploy/charts/litellm/templates/_helpers.tpl b/deploy/charts/litellm/templates/_helpers.tpl index fa563fadc..a1eda28c6 100644 --- a/deploy/charts/litellm/templates/_helpers.tpl +++ b/deploy/charts/litellm/templates/_helpers.tpl @@ -65,6 +65,20 @@ Create the name of the service account to use Get redis service name */}} {{- define "litellm.redis.serviceName" -}} -{{- printf "%s-headless" (default "redis" .Values.redis.nameOverride | trunc 63 | trimSuffix "-") -}} +{{- if and (eq .Values.redis.architecture "standalone") .Values.redis.sentinel.enabled -}} +{{- printf "%s-%s" .Release.Name (default "redis" .Values.redis.nameOverride | trunc 63 | trimSuffix "-") -}} +{{- else -}} +{{- printf "%s-%s-master" .Release.Name (default "redis" .Values.redis.nameOverride | trunc 63 | trimSuffix "-") -}} +{{- end -}} {{- end -}} +{{/* +Get redis service port +*/}} +{{- define "litellm.redis.port" -}} +{{- if .Values.redis.sentinel.enabled -}} +{{ .Values.redis.sentinel.service.ports.sentinel }} +{{- else -}} +{{ .Values.redis.master.service.ports.redis }} +{{- end -}} +{{- end -}} diff --git a/deploy/charts/litellm/templates/deployment.yaml b/deploy/charts/litellm/templates/deployment.yaml index 42cf84935..736f35680 100644 --- a/deploy/charts/litellm/templates/deployment.yaml +++ b/deploy/charts/litellm/templates/deployment.yaml @@ -144,9 +144,9 @@ spec: key: masterkey {{- if .Values.redis.enabled }} - name: REDIS_HOST - value: {{ template "litellm.redis.serviceName" . }} + value: {{ include "litellm.redis.serviceName" . }} - name: REDIS_PORT - value: {{ if .Values.redis.sentinel.enabled }}{{ .Values.redis.sentinel.service.ports.sentinel }}{{ else }}{{ .Values.redis.master.service.ports.redis}}{{ end }} + value: {{ include "litellm.redis.port" . | quote }} - name: REDIS_PASSWORD valueFrom: secretKeyRef: diff --git a/deploy/charts/litellm/values.yaml b/deploy/charts/litellm/values.yaml index 9b697b013..1d8f9ba3e 100644 --- a/deploy/charts/litellm/values.yaml +++ b/deploy/charts/litellm/values.yaml @@ -87,6 +87,8 @@ proxy_config: api_key: eXaMpLeOnLy general_settings: master_key: os.environ/PROXY_MASTER_KEY +# litellm_settings: +# cache: true resources: {} # We usually recommend not to specify default resources and to leave this as a conscious @@ -172,3 +174,4 @@ postgresql: # with cache: true to use existing redis instance redis: enabled: false + architecture: replication From 5777aeb36e679c26b6c3dca39405601a321468e9 Mon Sep 17 00:00:00 2001 From: Debdut Chakraborty Date: Sun, 10 Mar 2024 03:09:00 +0530 Subject: [PATCH 70/74] chore: set simpler redis architecture as default --- deploy/charts/litellm/values.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/deploy/charts/litellm/values.yaml b/deploy/charts/litellm/values.yaml index 1d8f9ba3e..3ae089636 100644 --- a/deploy/charts/litellm/values.yaml +++ b/deploy/charts/litellm/values.yaml @@ -174,4 +174,4 @@ postgresql: # with cache: true to use existing redis instance redis: enabled: false - architecture: replication + architecture: standalone From ba271e3e87abc98ca6c99d3cea6bbc8c34af8d59 Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Sat, 9 Mar 2024 13:41:20 -0800 Subject: [PATCH 71/74] (docs) deploying litell --- docs/my-website/docs/proxy/deploy.md | 62 ++++++++++++++++++++++++---- docs/my-website/sidebars.js | 8 ++-- 2 files changed, 57 insertions(+), 13 deletions(-) diff --git a/docs/my-website/docs/proxy/deploy.md b/docs/my-website/docs/proxy/deploy.md index 496bde05f..655d93b6b 100644 --- a/docs/my-website/docs/proxy/deploy.md +++ b/docs/my-website/docs/proxy/deploy.md @@ -28,7 +28,7 @@ docker run ghcr.io/berriai/litellm:main-latest -### Run with LiteLLM CLI args +#### Run with LiteLLM CLI args See all supported CLI args [here](https://docs.litellm.ai/docs/proxy/cli): @@ -129,13 +129,25 @@ spec: name: litellm-config-file ``` -> [!TIP] -> To avoid issues with predictability, difficulties in rollback, and inconsistent environments, use versioning or SHA digests (for example, `litellm:main-v1.30.3` or `litellm@sha256:12345abcdef...`) instead of `litellm:main-latest`. +:::info +To avoid issues with predictability, difficulties in rollback, and inconsistent environments, use versioning or SHA digests (for example, `litellm:main-v1.30.3` or `litellm@sha256:12345abcdef...`) instead of `litellm:main-latest`. +::: +**That's it ! That's the quick start to deploy litellm** + +## Options to deploy LiteLLM + +| Method | When to Use | Docs | +| --- | --- | --- | +| LiteLLM - Quick Start | call 100+ LLMs + Load Balancing | [Quick Start](#quick-start) | +| LiteLLM Database container + PostgresDB | + use Virtual Keys + Track Spend | [Deploy with Database](#deploy-with-database) | +| LiteLLM container + Redis | + load balance across multiple litellm containers | [LiteLLM container + Redis](#litellm-container--redis) | +| LiteLLM Database container + PostgresDB + Redis | + use Virtual Keys + Track Spend + load balance across multiple litellm containers | [LiteLLM container + Redis](#litellm-container--redis) | + ## Deploy with Database We maintain a [seperate Dockerfile](https://github.com/BerriAI/litellm/pkgs/container/litellm-database) for reducing build time when running LiteLLM proxy with a connected Postgres Database @@ -159,7 +171,7 @@ Your OpenAI proxy server is now running on `http://0.0.0.0:4000`. -### Step 1. Create deployment.yaml +#### Step 1. Create deployment.yaml ```yaml apiVersion: apps/v1 @@ -188,7 +200,7 @@ Your OpenAI proxy server is now running on `http://0.0.0.0:4000`. kubectl apply -f /path/to/deployment.yaml ``` -### Step 2. Create service.yaml +#### Step 2. Create service.yaml ```yaml apiVersion: v1 @@ -209,7 +221,7 @@ spec: kubectl apply -f /path/to/service.yaml ``` -### Step 3. Start server +#### Step 3. Start server ``` kubectl port-forward service/litellm-service 4000:4000 @@ -220,13 +232,13 @@ Your OpenAI proxy server is now running on `http://0.0.0.0:4000`. -### Step 1. Clone the repository +#### Step 1. Clone the repository ```bash git clone https://github.com/BerriAI/litellm.git ``` -### Step 2. Deploy with Helm +#### Step 2. Deploy with Helm ```bash helm install \ @@ -235,7 +247,7 @@ helm install \ deploy/charts/litellm ``` -### Step 3. Expose the service to localhost +#### Step 3. Expose the service to localhost ```bash kubectl \ @@ -249,6 +261,38 @@ Your OpenAI proxy server is now running on `http://127.0.0.1:8000`. +## LiteLLM container + Redis +Use Redis when you need litellm to load balance across multiple litellm containers + +The only change required is setting Redis on your `config.yaml` +LiteLLM Proxy supports sharing rpm/tpm shared across multiple litellm instances, pass `redis_host`, `redis_password` and `redis_port` to enable this. (LiteLLM will use Redis to track rpm/tpm usage ) + +```yaml +model_list: + - model_name: gpt-3.5-turbo + litellm_params: + model: azure/ + api_base: + api_key: + rpm: 6 # Rate limit for this deployment: in requests per minute (rpm) + - model_name: gpt-3.5-turbo + litellm_params: + model: azure/gpt-turbo-small-ca + api_base: https://my-endpoint-canada-berri992.openai.azure.com/ + api_key: + rpm: 6 +router_settings: + redis_host: + redis_password: + redis_port: 1992 +``` + +Start docker container with config + +```shell +docker run ghcr.io/berriai/litellm:main-latest --config your_config.yaml +``` + ## Best Practices for Deploying to Production ### 1. Switch of debug logs in production don't use [`--detailed-debug`, `--debug`](https://docs.litellm.ai/docs/proxy/debugging#detailed-debug) or `litellm.set_verbose=True`. We found using debug logs can add 5-10% latency per LLM API call diff --git a/docs/my-website/sidebars.js b/docs/my-website/sidebars.js index 33720b43e..62a2d3842 100644 --- a/docs/my-website/sidebars.js +++ b/docs/my-website/sidebars.js @@ -42,10 +42,6 @@ const sidebars = { "proxy/team_based_routing", "proxy/ui", "proxy/budget_alerts", - "proxy/model_management", - "proxy/health", - "proxy/debugging", - "proxy/pii_masking", { "type": "category", "label": "🔥 Load Balancing", @@ -54,6 +50,10 @@ const sidebars = { "proxy/reliability", ] }, + "proxy/model_management", + "proxy/health", + "proxy/debugging", + "proxy/pii_masking", "proxy/caching", { "type": "category", From a0042401094b760dadda53bbf083f508e21f7a4e Mon Sep 17 00:00:00 2001 From: ishaan-jaff Date: Sat, 9 Mar 2024 13:45:07 -0800 Subject: [PATCH 72/74] (docs) deploy litellm --- docs/my-website/docs/proxy/deploy.md | 48 ++++++++++++++++++++++++---- 1 file changed, 42 insertions(+), 6 deletions(-) diff --git a/docs/my-website/docs/proxy/deploy.md b/docs/my-website/docs/proxy/deploy.md index 655d93b6b..7c336e66f 100644 --- a/docs/my-website/docs/proxy/deploy.md +++ b/docs/my-website/docs/proxy/deploy.md @@ -141,12 +141,13 @@ To avoid issues with predictability, difficulties in rollback, and inconsistent ## Options to deploy LiteLLM -| Method | When to Use | Docs | -| --- | --- | --- | -| LiteLLM - Quick Start | call 100+ LLMs + Load Balancing | [Quick Start](#quick-start) | -| LiteLLM Database container + PostgresDB | + use Virtual Keys + Track Spend | [Deploy with Database](#deploy-with-database) | -| LiteLLM container + Redis | + load balance across multiple litellm containers | [LiteLLM container + Redis](#litellm-container--redis) | -| LiteLLM Database container + PostgresDB + Redis | + use Virtual Keys + Track Spend + load balance across multiple litellm containers | [LiteLLM container + Redis](#litellm-container--redis) | +| Docs | When to Use | +| --- | --- | +| [Quick Start](#quick-start) | call 100+ LLMs + Load Balancing | +| [Deploy with Database](#deploy-with-database) | + use Virtual Keys + Track Spend | +| [LiteLLM container + Redis](#litellm-container--redis) | + load balance across multiple litellm containers | +| [LiteLLM Database container + PostgresDB + Redis](#litellm-database-container--postgresdb--redis) | + use Virtual Keys + Track Spend + load balance across multiple litellm containers | + ## Deploy with Database @@ -293,6 +294,41 @@ Start docker container with config docker run ghcr.io/berriai/litellm:main-latest --config your_config.yaml ``` +## LiteLLM Database container + PostgresDB + Redis + +The only change required is setting Redis on your `config.yaml` +LiteLLM Proxy supports sharing rpm/tpm shared across multiple litellm instances, pass `redis_host`, `redis_password` and `redis_port` to enable this. (LiteLLM will use Redis to track rpm/tpm usage ) + + +```yaml +model_list: + - model_name: gpt-3.5-turbo + litellm_params: + model: azure/ + api_base: + api_key: + rpm: 6 # Rate limit for this deployment: in requests per minute (rpm) + - model_name: gpt-3.5-turbo + litellm_params: + model: azure/gpt-turbo-small-ca + api_base: https://my-endpoint-canada-berri992.openai.azure.com/ + api_key: + rpm: 6 +router_settings: + redis_host: + redis_password: + redis_port: 1992 +``` + +Start `litellm-database`docker container with config + +```shell +docker run --name litellm-proxy \ +-e DATABASE_URL=postgresql://:@:/ \ +-p 4000:4000 \ +ghcr.io/berriai/litellm-database:main-latest --config your_config.yaml +``` + ## Best Practices for Deploying to Production ### 1. Switch of debug logs in production don't use [`--detailed-debug`, `--debug`](https://docs.litellm.ai/docs/proxy/debugging#detailed-debug) or `litellm.set_verbose=True`. We found using debug logs can add 5-10% latency per LLM API call From 8b24ddcbbdc7094df8c20a9e6340934391542120 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Sat, 9 Mar 2024 14:02:27 -0800 Subject: [PATCH 73/74] fix(bedrock.py): enable claude-3 streaming --- litellm/llms/bedrock.py | 2 ++ litellm/tests/test_streaming.py | 25 +++++++++++++++++++++++++ litellm/utils.py | 11 +++++++++-- 3 files changed, 36 insertions(+), 2 deletions(-) diff --git a/litellm/llms/bedrock.py b/litellm/llms/bedrock.py index 89d1bf16f..4aa27b3c9 100644 --- a/litellm/llms/bedrock.py +++ b/litellm/llms/bedrock.py @@ -126,6 +126,8 @@ class AmazonAnthropicClaude3Config: optional_params["max_tokens"] = value if param == "tools": optional_params["tools"] = value + if param == "stream": + optional_params["stream"] = value return optional_params diff --git a/litellm/tests/test_streaming.py b/litellm/tests/test_streaming.py index 2896b4a71..6f8d73c31 100644 --- a/litellm/tests/test_streaming.py +++ b/litellm/tests/test_streaming.py @@ -727,6 +727,31 @@ def test_completion_claude_stream_bad_key(): # pytest.fail(f"Error occurred: {e}") +def test_bedrock_claude_3_streaming(): + try: + litellm.set_verbose = True + response: ModelResponse = completion( + model="bedrock/anthropic.claude-3-sonnet-20240229-v1:0", + messages=messages, + max_tokens=10, + stream=True, + ) + complete_response = "" + # Add any assertions here to check the response + for idx, chunk in enumerate(response): + chunk, finished = streaming_format_tests(idx, chunk) + if finished: + break + complete_response += chunk + if complete_response.strip() == "": + raise Exception("Empty response received") + print(f"completion_response: {complete_response}") + except RateLimitError: + pass + except Exception as e: + pytest.fail(f"Error occurred: {e}") + + @pytest.mark.skip(reason="Replicate changed exceptions") def test_completion_replicate_stream_bad_key(): try: diff --git a/litellm/utils.py b/litellm/utils.py index 7466bd5c6..6d42ec2d3 100644 --- a/litellm/utils.py +++ b/litellm/utils.py @@ -8778,13 +8778,20 @@ class CustomStreamWrapper: text = chunk_data.get("completions")[0].get("data").get("text") is_finished = True finish_reason = "stop" - # anthropic mapping - elif "completion" in chunk_data: + ######## bedrock.anthropic mappings ############### + elif "completion" in chunk_data: # not claude-3 text = chunk_data["completion"] # bedrock.anthropic stop_reason = chunk_data.get("stop_reason", None) if stop_reason != None: is_finished = True finish_reason = stop_reason + elif "delta" in chunk_data: + if chunk_data["delta"].get("text", None) is not None: + text = chunk_data["delta"]["text"] + stop_reason = chunk_data["delta"].get("stop_reason", None) + if stop_reason != None: + is_finished = True + finish_reason = stop_reason ######## bedrock.cohere mappings ############### # meta mapping elif "generation" in chunk_data: From 86fe7a9af175ad7d9e51b1cf26d714cec3f623b0 Mon Sep 17 00:00:00 2001 From: Krrish Dholakia Date: Sat, 9 Mar 2024 18:42:01 -0800 Subject: [PATCH 74/74] fix(anthropic.py): deep copy messages before popping system prompt --- litellm/llms/anthropic.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/litellm/llms/anthropic.py b/litellm/llms/anthropic.py index 5e0887901..becbcc328 100644 --- a/litellm/llms/anthropic.py +++ b/litellm/llms/anthropic.py @@ -1,7 +1,7 @@ import os, types import json from enum import Enum -import requests +import requests, copy import time, uuid from typing import Callable, Optional from litellm.utils import ModelResponse, Usage, map_finish_reason @@ -117,6 +117,7 @@ def completion( ): headers = validate_environment(api_key, headers) _is_function_call = False + messages = copy.deepcopy(messages) if model in custom_prompt_dict: # check if the model has a registered custom prompt model_prompt_details = custom_prompt_dict[model]