Heroku Only开发环境有Chrome版本81的问题



我使用的是带有硒元素的heroku,带有heroku/google chrome和heroku/chromedriver构建包。最近对谷歌chrome进行了更新,谷歌chrome构建包也进行了更新。

编辑:我在我的开发实例上看到

/app/.apt/opt/google/chrome/chrome --version
Google Chrome 80.0.3987.163 unknown

但在我的产品实例上,它工作于

Google Chrome 81.0.4044.92 unknown

所以问题是如何在heroku上强制使用这个版本?

下面的旧信息现在可能不那么相关了。

然而,尽管如此,我现在还是看到了chrome版本错误,但仅限于我的开发实例。当我直接使用生产实例进行构建时,它运行良好。然而,我的典型过程是使用我的开发实例进行构建和测试,然后将该精确构建提升到生产实例,现在这将提升一个损坏的构建。

错误如下:

2020-04-09T22:20:56.505318+00:00 app[celery_worker.1]: [2020-04-09 22:20:56,504: ERROR/ForkPoolWorker-1] Task ... raised unexpected: SessionNotCreatedException('session not created: This version of ChromeDriver only supports Chrome version 81', None, None)
...
2020-04-09T22:20:56.505336+00:00 app[celery_worker.1]: 'CHROMEDRIVER_PATH', ''), chrome_options=chrome_options)
2020-04-09T22:20:56.505336+00:00 app[celery_worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/seleniumwire/webdriver/browser.py", line 88, in __init__
2020-04-09T22:20:56.505337+00:00 app[celery_worker.1]: super().__init__(*args, **kwargs)
2020-04-09T22:20:56.505337+00:00 app[celery_worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/selenium/webdriver/chrome/webdriver.py", line 81, in __init__
2020-04-09T22:20:56.505338+00:00 app[celery_worker.1]: desired_capabilities=desired_capabilities)
2020-04-09T22:20:56.505338+00:00 app[celery_worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/selenium/webdriver/remote/webdriver.py", line 157, in __init__
2020-04-09T22:20:56.505339+00:00 app[celery_worker.1]: self.start_session(capabilities, browser_profile)
2020-04-09T22:20:56.505339+00:00 app[celery_worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/selenium/webdriver/remote/webdriver.py", line 252, in start_session
2020-04-09T22:20:56.505339+00:00 app[celery_worker.1]: response = self.execute(Command.NEW_SESSION, parameters)
2020-04-09T22:20:56.505340+00:00 app[celery_worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/selenium/webdriver/remote/webdriver.py", line 321, in execute
2020-04-09T22:20:56.505340+00:00 app[celery_worker.1]: self.error_handler.check_response(response)
2020-04-09T22:20:56.505341+00:00 app[celery_worker.1]: File "/app/.heroku/python/lib/python3.6/site-packages/selenium/webdriver/remote/errorhandler.py", line 242, in check_response
2020-04-09T22:20:56.505342+00:00 app[celery_worker.1]: raise exception_class(message, screen, stacktrace)
2020-04-09T22:20:56.505342+00:00 app[celery_worker.1]: selenium.common.exceptions.SessionNotCreatedException: Message: session not created: This version of ChromeDriver only supports Chrome version 81

据我所知,我的开发实例基本上与我的生产实例完全相同,但显然情况并非如此。buildpacks和requirements.txt完全相同,构建日志也几乎相同我确实在构建日志中看到了这种差异,开发版本有:

-----> Installing libasound2_1.1.3-5ubuntu0.2_amd64.deb
-----> Installing libasound2_1.1.3-5ubuntu0.4_amd64.deb
-----> Installing libasound2-data_1.1.3-5ubuntu0.2_all.deb
-----> Installing libasound2-data_1.1.3-5ubuntu0.4_all.deb

但是生产版本只有

-----> Installing libasound2_1.1.3-5ubuntu0.4_amd64.deb
-----> Installing libasound2-data_1.1.3-5ubuntu0.4_all.deb

不过,这似乎是在转移注意力。

以下是heroku/google chrome构建包中可能存在的相关问题:https://github.com/heroku/heroku-buildpack-google-chrome/pull/85

其他人看到了这一点,知道如何让开发构建工作,或者如何让selenium再次在heroku上工作吗?

我找到了修复方法,你需要重置你的缓存

$ heroku plugins:install heroku-repo
$ heroku repo:purge_cache -a appname

然后使用空提交重新部署或从master进行部署。

它之所以在开发上失败,是因为我从未在生产堆栈上构建过,因此它没有旧chrome版本的缓存。

https://help.heroku.com/18PI5RSY/how-do-i-clear-the-build-cache

相关内容

  • 没有找到相关文章

最新更新