python 与OpenAi连接时出现松果错误:MaxRetryError

axr492tv  于 2023-05-27  发布在  Python
关注(0)|答案(2)|浏览(330)

我有一个简单的应用程序,可以让你上传一个pdf,把它分成块,嵌入,然后上传到松果。但是当我运行docsearch = Pinecone.from_texts([t.page_content for t in texts], embeddings, index_name=index_name)时,我得到以下错误:

SSLEOFError                               Traceback (most recent call last)
File /usr/lib/python3/dist-packages/urllib3/connectionpool.py:699, in HTTPConnectionPool.urlopen(self, method, url, body, headers, retries, redirect, assert_same_host, timeout, pool_timeout, release_conn, chunked, body_pos, **response_kw)
    698 # Make the request on the httplib connection object.
--> 699 httplib_response = self._make_request(
    700     conn,
    701     method,
    702     url,
    703     timeout=timeout_obj,
    704     body=body,
    705     headers=headers,
    706     chunked=chunked,
    707 )
    709 # If we're going to release the connection in ``finally:``, then
    710 # the response doesn't need to know about the connection. Otherwise
    711 # it will also try to release it and we'll have a double-release
    712 # mess.

File /usr/lib/python3/dist-packages/urllib3/connectionpool.py:394, in HTTPConnectionPool._make_request(self, conn, method, url, timeout, chunked, **httplib_request_kw)
    393     else:
--> 394         conn.request(method, url, **httplib_request_kw)
    396 # We are swallowing BrokenPipeError (errno.EPIPE) since the server is
    397 # legitimately able to close the connection after sending a valid response.
    398 # With this behaviour, the received response is still readable.
...
--> 574     raise MaxRetryError(_pool, url, error or ResponseError(cause))
    576 log.debug("Incremented Retry for (url='%s'): %r", url, new_retry)
    578 return new_retry

MaxRetryError: HTTPSConnectionPool(host='langchain2-e630e5d.svc.asia-northeast1-gcp.pinecone.io', port=443): Max retries exceeded with url: /vectors/upsert (Caused by SSLError(SSLEOFError(8, 'EOF occurred in violation of protocol (_ssl.c:2396)')))

我不知道错误是什么。
下面是代码的其余部分:

from langchain.text_splitter import RecursiveCharacterTextSplitter

Load your data

loader = UnstructuredPDFLoader("../data/field-guide-to-data-science.pdf")
# loader = OnlinePDFLoader("https://wolfpaulus.com/wp-content/uploads/2017/05/field-guide-to-data-science.pdf")

data = loader.load()

print (f'You have {len(data)} document(s) in your data')
print (f'There are {len(data[0].page_content)} characters in your document')

You have 1 document(s) in your data
There are 176584 characters in your document

Chunk your data up into smaller documents

text_splitter = RecursiveCharacterTextSplitter(chunk_size=1000, chunk_overlap=0)
texts = text_splitter.split_documents(data)

print (f'Now you have {len(texts)} documents')

Now you have 228 documents

Create embeddings of your documents to get ready for semantic search

from langchain.vectorstores import Chroma, Pinecone
from langchain.embeddings.openai import OpenAIEmbeddings
import pinecone

OPENAI_API_KEY = '...'
PINECONE_API_KEY = '...'
PINECONE_API_ENV = 'us-east1-gcp'

embeddings = OpenAIEmbeddings(openai_api_key=OPENAI_API_KEY)

# initialize pinecone
pinecone.init(
    api_key=PINECONE_API_KEY,  # find at app.pinecone.io
    environment=PINECONE_API_ENV  # next to api key in console
)
index_name = "langchain2"

docsearch = Pinecone.from_texts([t.page_content for t in texts], embeddings, index_name=index_name)```
m3eecexj

m3eecexj1#

这是一个SSL协议错误-您缺少一些依赖项:

pip install ndg-httpsclient
pip install pyopenssl
pip install pyasn1

祝你好运

5us2dqdw

5us2dqdw2#

检查您的PINECONE_ENVIRONMENT设置

相关问题