>백엔드 개발 >파이썬 튜토리얼 >수파베이스 파이썬

수파베이스 파이썬

王林
王林원래의
2024-08-31 06:04:36860검색

Supabase Python

Supabase 커뮤니티가 성장함에 따라 다양한 클라이언트 라이브러리 컬렉션과 프레임워크별 SDK에 대한 수요도 늘어났습니다. 이러한 요구는 대부분 현재 수십 개의 라이브러리를 유지 관리하는 오픈 소스 커뮤니티 자체에서 충족되었습니다.

⚡️ 출시 주간에 대한 자세한 내용

사람들이 호스팅된 Supabase 서비스에 요청하면 우리는 이러한 라이브러리 중 일부가 얼마나 광범위하게 사용되는지에 대한 좋은 그림을 그릴 수 있으며, 특정 라이브러리가 폭넓게 채택되면 다음에 대한 공식 지원을 추가하는 것이 합리적입니다. 그것. 커뮤니티 지원에서 공식 지원으로 도약한 라이브러리의 예로는 supabase-flutter 및 supabase-swift가 있습니다.

지난 1년 반 동안 Python 클라이언트 라이브러리에 대한 커뮤니티 지원은 항상 놀라운 수준이었습니다. 그러나 채택이 크게 급증했습니다. 이는 AI 및 ML 커뮤니티에서 Supabase가 폭넓게 채택된 데 힘입은 것이며, 그 중 다수는 열렬한 Pythonistas입니다.

그래서 오늘 우리는 다음 Python 클라이언트 라이브러리가 이제 Supabase 플랫폼에서 공식적으로 지원된다는 사실을 발표합니다.

  • 수파베이스-py
  • 인증
  • 스토리지파이
  • 함수-py
  • 실시간 파이

supabase-py는 원래 관리자 lqmanh에 의해 2020년 9월에 시작되었고 얼마 지나지 않아 fedden과 J0(Supabase 팀의 정규 멤버가 됨)가 합류했습니다. 최근 몇 년 동안은 Silentworks와 juancarlospaco가 개발을 주도했으며 둘 다 supabase-js와의 기능 동등성을 달성하는 데 중요한 역할을 했습니다.

지금까지 클라이언트 라이브러리에 기여해 주신 모든 분들께 진심으로 감사드리며 앞으로는 더 많은 커뮤니티 라이브러리가 공식 지원을 추진하는 모습을 볼 수 있기를 바랍니다.

다음은 Python 라이브러리 컬렉션에 추가된 최근 기능 중 일부에 대한 개요입니다.

기본적으로 HTTP2를 활성화합니다.

Supabase 클라이언트는 기본적으로 사용 가능한 경우 자동으로 HTTP 2.0을 사용하여 기존 애플리케이션에 원활한 성능 향상을 제공합니다.

이 개선 사항은 완전히 투명한 방식으로 구현되며 기존 코드를 변경할 필요가 없으며 잠재적으로 상당한 지연 시간 감소와 성능 향상을 제공합니다.

참조:

  • https://github.com/supabase/functions-py/pull/115
  • https://github.com/supabase/auth-py/pull/534
  • https://github.com/supabase/postgrest-py/pull/462
  • https://github.com/supabase/storage-py/pull/271

기본적으로 리디렉션을 따릅니다.

이제 Supabase 클라이언트는 기본적으로 모든 HTTP 리디렉션을 자동으로 따르며 다른 프로그래밍 언어의 Supabase 클라이언트 동작에 맞춰 조정됩니다.

이번 개선 사항은 생태계 전체의 일관성을 향상시키고 리디렉션 처리를 단순화하여 URL 변경이나 로드 밸런싱과 같은 일반적인 시나리오에서 수동 개입의 필요성을 줄입니다.

참조:

  • https://github.com/supabase/postgrest-py/pull/449
  • https://github.com/supabase/functions-py/pull/107
  • https://github.com/supabase/storage-py/pull/257
  • https://github.com/supabase/auth-py/pull/511

기본적으로 연결 유지가 활성화되어 있습니다.

Supabase 클라이언트는 이제 기본적으로 연결 유지 HTTP 헤더를 자동으로 포함합니다. 이 헤더는 때때로 누락되어 이전 버전의 이러한 불일치를 해결합니다.

이번 개선 사항은 연결 관리를 최적화하고 잠재적으로 대기 시간을 줄이며 서버와의 지속적인 연결을 유지하여 성능을 향상시킵니다. 특히 매우 자주 API 호출을 수행하는 애플리케이션에 유용합니다.

간선 기능 영역

에지 기능이 실행될 지역을 지정하는 지원이 추가되었습니다(지역은 기본적으로 세계의 물리적 위치입니다).

참조:

  • https://github.com/supabase/functions-py/pull/126

실시간 V2

Realtime은 업데이트된 예시와 새로운 Presence 관련 기능(방송, 구독, 추적 등)을 포함하여 많은 개선과 수정을 통해 버전 2.0으로 업그레이드되었습니다.

참조:

  • https://github.com/supabase/realtime-py/pull/139
  • https://github.com/supabase/realtime-py/pull/178

인증 개선

사용자 클래스에 추가된 새로운 is_anonymous 부울 속성을 포함하여 익명 로그인이 인증 클라이언트에 추가되었습니다. 또한 sign_in_with_id_token() 및 sign_in_with_sso() 메소드가 인증 클라이언트에 추가되었습니다. 버그 수정.

참조:

  • https://github.com/supabase/auth-py/pull/528
  • https://github.com/supabase/auth-py/pull/548
  • https://github.com/supabase/auth-py/pull/553
  • https://github.com/supabase/auth-py/pull/506

쿼리에서 Postgrest 인용/이스케이프

Supabase는 클라이언트측 내부 SQL 쿼리의 매개변수 삭제를 위해 sanitize_param()을 구현하여 PostgreSQL 쿼리 안전성을 향상시켜 모든 작업에서 보다 안전한 데이터 처리 및 쿼리 실행을 보장합니다.

확인되지 않은 SSL로 실행

일부 사용자는 어떤 이유로든 유효하지 않거나 확인되지 않은 SSL을 사용하여 Supabase 클라이언트를 실행해야 합니다(개발 환경의 SSL 디버거/추적자/프로파일러/등). 새로운 선택적 부울 인수가 클라이언트 생성자에 추가된 다음 확인을 전달합니다. =False를 사용하면 경고 없이 확인되지 않은 SSL로 실행할 수 있습니다.

from postgrest import SyncPostgrestClient

url: str = "https://example.com"
h: dict = {"Custom-Header": "value"}

with SyncPostgrestClient(url, schema="pub", headers=h, verify = False) as client:
    session = client.session
    assert session.base_url == "https://example.com"

참조:

  • https://github.com/supabase/functions-py/pull/106
  • https://github.com/supabase/storage-py/pull/256
  • https://github.com/supabase/auth-py/pull/506
  • https://github.com/supabase/postgrest-py/pull/448
  • https://github.com/supabase/supabase-py/pull/813

실시간으로 소켓 닫기

이제 Supabase Realtime 라이브러리에는 소켓 연결을 닫기 위한 새로운 close() 메서드가 포함되어 있습니다.

이 추가 기능을 통해 개발자는 연결 수명 주기를 보다 세밀하게 제어할 수 있으므로 필요할 때 소켓 연결을 명시적으로 닫을 수 있습니다.

import os
from realtime import AsyncRealtimeClient

def callback1(payload):
    print("Callback 1: ", payload)

SUPABASE_ID: str = os.environ.get("SUPABASE_ID")
API_KEY: str = os.environ.get("SUPABASE_KEY")

URL: str = f"wss://{SUPABASE_ID}.supabase.co/realtime/v1/websocket"

client = AsyncRealtimeClient(URL, API_KEY)
await client.connect()

channel_1 = s.channel("realtime:public:sample")
channel_1.subscribe().on_postgres_changes("INSERT", callback1)

await client.listen()
await client.close()

참조:

  • https://github.com/supabase-community/realtime-py/pull/142

Edge Functions 시간 초과

Edge 기능에 대한 시간 초과가 수정되었으며 장기 실행 기능이 올바르게 종료됩니다. 더 이상 기능을 차단하는 라이브러리 클라이언트 측 내부 시간 초과가 없습니다.

이제 사용자는 Edge Functions에서 더욱 복잡한 작업을 자신 있게 구현할 수 있습니다.

import os
from supabase import create_client
from supabase.lib.client_options import ClientOptions

url: str = os.environ.get("SUPABASE_URL")
key: str = os.environ.get("SUPABASE_KEY")

options = ClientOptions(function_client_timeout = 15)
client = create_client(url, key, options)

client.functions.url = "http://127.0.0.1:54321/functions/v1/hello-world"
print(client.functions.invoke("hello"))

참조:

  • https://github.com/supabase/functions-py/pull/120
  • https://github.com/supabase/supabase-py/pull/846

데이터를 Supabase로 마이그레이션하는 새로운 도구 Vec2pg

다른 서비스 및 SASS의 벡터 데이터를 Supabase로 마이그레이션하는 간단하고 확장 가능한 새로운 CLI 도구가 생성되었습니다. 이 도구는 단일 명령으로 Pinecone 및 Qdrant의 벡터 데이터를 Supabase로 마이그레이션하여 워크플로를 간소화하고 AI 및 ML 전반에 걸쳐 데이터 이식성을 향상시킬 수 있습니다. 프로젝트.

향후 추가될 다른 벡터 데이터베이스 제공업체에 투표할 수 있습니다!

참조:

  • https://github.com/supabase-community/vec2pg
  • https://github.com/supabase-community/vec2pg/pull/5
  • https://github.com/supabase-community/vec2pg/issues/6

업데이트된 CI

모든 라이브러리에 대한 지속적 통합 빌드가 업그레이드되어 더욱 엄격해졌습니다(linter 등).

참조:

  • https://github.com/supabase/supabase-py/pull/772
  • https://github.com/supabase/supabase-py/pull/774
  • https://github.com/supabase/functions-py/pull/93
  • https://github.com/supabase/functions-py/pull/92
  • https://github.com/supabase/storage-py/pull/240
  • https://github.com/supabase/storage-py/pull/237
  • https://github.com/supabase/realtime-py/pull/132
  • https://github.com/supabase/realtime-py/pull/131
  • https://github.com/supabase/postgrest-py/pull/424
  • https://github.com/supabase/postgrest-py/pull/422
  • https://github.com/supabase/functions-py/pull/139
  • https://github.com/supabase/storage-py/pull/287
  • https://github.com/supabase/auth-py/pull/572
  • https://github.com/supabase/postgrest-py/pull/484
  • https://github.com/supabase/supabase-py/pull/887
  • https://github.com/supabase/realtime-py/pull/182

여러 가지 잡다한

  • 모든 코드 저장소에서 Unittests 적용 범위가 향상되었습니다.
  • 모든 라이브러리(mccabe, Prospector)에서 순환적 복잡성이 분석되어 개선되었습니다.
  • 코드 스타일, 기호 이름 지정, 문서, 주석 및 독스트링에 대한 여러 수정 사항.

기여

Python 클라이언트 라이브러리에 기여하고 싶다면 여기에서 기여 방법에 대한 정보를 확인하고, 공개 문제 목록을 확인하여 작업할 내용에 대한 영감을 얻으세요.

시작하기

Supabase Docs 사이트에서 Supabase Python 클라이언트 라이브러리에 대한 전체 문서를 볼 수 있습니다.

위 내용은 수파베이스 파이썬의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.