• <tfoot id='6HmtD'></tfoot>
    <i id='6HmtD'><tr id='6HmtD'><dt id='6HmtD'><q id='6HmtD'><span id='6HmtD'><b id='6HmtD'><form id='6HmtD'><ins id='6HmtD'></ins><ul id='6HmtD'></ul><sub id='6HmtD'></sub></form><legend id='6HmtD'></legend><bdo id='6HmtD'><pre id='6HmtD'><center id='6HmtD'></center></pre></bdo></b><th id='6HmtD'></th></span></q></dt></tr></i><div id='6HmtD'><tfoot id='6HmtD'></tfoot><dl id='6HmtD'><fieldset id='6HmtD'></fieldset></dl></div>

    1. <small id='6HmtD'></small><noframes id='6HmtD'>

    2. <legend id='6HmtD'><style id='6HmtD'><dir id='6HmtD'><q id='6HmtD'></q></dir></style></legend>
        <bdo id='6HmtD'></bdo><ul id='6HmtD'></ul>

        在 Python 中将 MySQL 与 AWS Lambda 结合使用的问题

        Problems using MySQL with AWS Lambda in Python(在 Python 中将 MySQL 与 AWS Lambda 结合使用的问题)
        <i id='isCXx'><tr id='isCXx'><dt id='isCXx'><q id='isCXx'><span id='isCXx'><b id='isCXx'><form id='isCXx'><ins id='isCXx'></ins><ul id='isCXx'></ul><sub id='isCXx'></sub></form><legend id='isCXx'></legend><bdo id='isCXx'><pre id='isCXx'><center id='isCXx'></center></pre></bdo></b><th id='isCXx'></th></span></q></dt></tr></i><div id='isCXx'><tfoot id='isCXx'></tfoot><dl id='isCXx'><fieldset id='isCXx'></fieldset></dl></div>
        • <bdo id='isCXx'></bdo><ul id='isCXx'></ul>
            <tbody id='isCXx'></tbody>

          <tfoot id='isCXx'></tfoot>

                • <legend id='isCXx'><style id='isCXx'><dir id='isCXx'><q id='isCXx'></q></dir></style></legend>

                  <small id='isCXx'></small><noframes id='isCXx'>

                  本文介绍了在 Python 中将 MySQL 与 AWS Lambda 结合使用的问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我正在尝试使用 AWS Lambda Python(Python 初学者)启动并运行,但在包含 MySQL 依赖项时遇到了一些问题.我正在尝试按照此处 在我的 Mac 上.

                  I am trying to get up and running with AWS Lambda Python (beginner in Python btw) but having some problems with including MySQL dependency. I am trying to follow the instructions here on my Mac.

                  对于第 3 步,我在项目根目录执行命令时遇到一些问题

                  For step number 3, I am getting some problems with doing the command at the root of my project

                  sudo pip install MySQL-python -t /
                  

                  错误:

                  异常:回溯(最近一次调用最后一次):文件/Library/Python/2.7/site-packages/pip-1.5.6-py2.7.egg/pip/basecommand.py",第 122 行,在 mainstatus = self.run(options, args)运行中的文件/Library/Python/2.7/site-packages/pip-1.5.6-py2.7.egg/pip/commands/install.py",第 311 行os.path.join(options.target_dir, item)文件/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/shutil.py",第 292 行,移动中引发错误,目标路径 '%s' 已经存在"% real_dst错误:目标路径'/MySQL_python-1.2.5-py2.7.egg-info/MySQL_python-1.2.5-py2.7.egg-info'已经存在

                  Exception: Traceback (most recent call last): File "/Library/Python/2.7/site-packages/pip-1.5.6-py2.7.egg/pip/basecommand.py", line 122, in main status = self.run(options, args) File "/Library/Python/2.7/site-packages/pip-1.5.6-py2.7.egg/pip/commands/install.py", line 311, in run os.path.join(options.target_dir, item) File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/shutil.py", line 292, in move raise Error, "Destination path '%s' already exists" % real_dst Error: Destination path '/MySQL_python-1.2.5-py2.7.egg-info/MySQL_python-1.2.5-py2.7.egg-info' already exists

                  我最终编写了以下 lambda 函数(在我的 Mac 上运行良好),即:

                  I end up writing my following lambda function (works fine on my Mac), which is:

                  import MySQLdb
                  
                  def lambda_handler(event, context):
                     # Open database connection
                     db = MySQLdb.connect(...)
                  
                     # prepare a cursor object using cursor() method
                     cursor = db.cursor()
                  
                     sql = "SELECT * FROM Users"
                  
                     try:
                        # Execute the SQL command
                        cursor.execute(sql)
                        # Fetch all the rows in a list of lists.
                        results = cursor.fetchall()
                        for row in results:
                           fname = row[0]
                           lname = row[1]
                           age = row[2]
                           sex = row[3]
                           income = row[4]
                           # Now print fetched result
                           print ("lname=%s" %(lname))
                     except:
                        print "Error: unable to fecth data"
                  
                     # disconnect from server
                     db.close()
                  

                  我接下来要做的是转到/Library/Python/2.7/site-packages 并复制我执行 sudo pip install MySQL-python(不带 -t/)时下载的 MySQLdb 文件夹/文件(我确定我在这里做错了),到我的 lambda 项目,然后将内容与 lambda_function.py 一起压缩并上传到 AWS Lambda.

                  What I went on to do is go to /Library/Python/2.7/site-packages and copying over the the MySQLdb folders/files that were downloaded when I did sudo pip install MySQL-python (without -t /) (I'm sure I'm doing something wrong here), to my lambda project, and then zipped the content along with the lambda_function.py and uploaded to AWS Lambda.

                  然后我得到:

                  无法导入模块lambda_function":没有名为 MySQLdb 的模块

                  Unable to import module 'lambda_function': No module named MySQLdb

                  感谢任何帮助和建议!

                  编辑

                  能够使 sudo pip install MySQL-python -t/pathToProject 工作(感谢评论中的帮助)但现在我在运行 lambda 函数时得到了这个:

                  Was able to do make sudo pip install MySQL-python -t /pathToProject work (thanks for the help in the comments) but now I get this when runing the lambda function:

                  无法导入模块lambda_function":/var/task/_mysql.so:ELF 标头无效

                  Unable to import module 'lambda_function': /var/task/_mysql.so: invalid ELF header

                  我知道如果我在 Linux 机器上工作,那么它应该可以正常工作(正如某些人所建议的那样),但我想知道我是否可以让它在 OS X 机器上工作.

                  I know that if I work on a Linux box, then it should work fine (as suggested by some people), but I am wondering if I can make it work from an OS X box.

                  推荐答案

                  对于像 Lambda 这样的用例,你会更高兴使用像 PyMySQL.

                  For a use case like Lambda you'll be a lot happier using a pure python implementation like PyMySQL.

                  它是 MySQLdb 的替代品,遵循 Python 数据库 API规格.对于诸如触发的 Lambda 事件之类的大多数事情,它也一样快.

                  It's a drop in replacement for MySQLdb that follows the Python Database API specification. For most things like triggered Lambda events it will be just as fast.

                  我在生产中经常使用它,而且效果很好.

                  I've used it in production a lot and it works great.

                  这篇关于在 Python 中将 MySQL 与 AWS Lambda 结合使用的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Is there a way to get a list of column names in sqlite?(有没有办法在sqlite中获取列名列表?)
                  Oracle Equivalent to MySQL INSERT IGNORE?(Oracle 相当于 MySQL INSERT IGNORE?)
                  Sqlite / SQLAlchemy: how to enforce Foreign Keys?(Sqlite/SQLAlchemy:如何强制使用外键?)
                  sqlite3.ProgrammingError: Incorrect number of bindings supplied. The current statement uses 1, and there are 74 supplied(sqlite3.ProgrammingError:提供的绑定数量不正确.当前语句使用1,提供了74)
                  How can I do a batch insert into an Oracle database using Python?(如何使用 Python 批量插入 Oracle 数据库?)
                  How to load existing db file to memory in Python sqlite3?(如何在 Python sqlite3 中将现有的 db 文件加载到内存中?)

                      <bdo id='ihZp2'></bdo><ul id='ihZp2'></ul>

                    • <legend id='ihZp2'><style id='ihZp2'><dir id='ihZp2'><q id='ihZp2'></q></dir></style></legend>

                      <tfoot id='ihZp2'></tfoot>
                            <tbody id='ihZp2'></tbody>
                        • <small id='ihZp2'></small><noframes id='ihZp2'>

                          1. <i id='ihZp2'><tr id='ihZp2'><dt id='ihZp2'><q id='ihZp2'><span id='ihZp2'><b id='ihZp2'><form id='ihZp2'><ins id='ihZp2'></ins><ul id='ihZp2'></ul><sub id='ihZp2'></sub></form><legend id='ihZp2'></legend><bdo id='ihZp2'><pre id='ihZp2'><center id='ihZp2'></center></pre></bdo></b><th id='ihZp2'></th></span></q></dt></tr></i><div id='ihZp2'><tfoot id='ihZp2'></tfoot><dl id='ihZp2'><fieldset id='ihZp2'></fieldset></dl></div>