Skip to content
Apache OpenWhisk runtime for Python language functions. https://openwhisk.apache.org/
Jupyter Notebook Python Scala Dockerfile Shell
Branch: master
Clone or download
dgrove-oss and rabbah gradlew licensing (#67)
Update gradlew[.bat] scripts from Gradle v5.5 release which
have proper Apache license headers and add corresponding
entry to LICENSE.txt.
Latest commit faf5316 Aug 1, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.github
core change travis builds to publish docker images with tag 'nightly' (#66) Jun 30, 2019
gradle Update all files using Mini license header to use full ASF header (#64) Jun 18, 2019
tests Update all files using Mini license header to use full ASF header (#64) Jun 18, 2019
tools/travis change travis builds to publish docker images with tag 'nightly' (#66) Jun 30, 2019
.gitattributes Use .gitattributes to correct EOL chars for bash scripts not having .… Jul 15, 2016
.gitignore update .gitignore out/ for intellij (#2756) Sep 15, 2017
.scalafmt.conf Update all files using Mini license header to use full ASF header (#64) Jun 18, 2019
.travis.yml change travis builds to publish docker images with tag 'nightly' (#66) Jun 30, 2019
CONTRIBUTING.md Fix markdown files with a typo. in the Hash license header. (#22) May 10, 2018
DISCLAIMER.txt Add the DISCLAIMER file for Apache incubator project (#28) Jun 12, 2018
LICENSE.txt gradlew licensing (#67) Aug 1, 2019
NOTICE.txt update end year to 2019 Mar 4, 2019
README.md Fix some typos and syntax errors on README.md (#65) Jul 12, 2019
build.gradle Last files to need ASF License headers. (#25) May 23, 2018
gradlew gradlew licensing (#67) Aug 1, 2019
gradlew.bat gradlew licensing (#67) Aug 1, 2019
settings.gradle remove build of python2 Jan 30, 2019

README.md

Apache OpenWhisk runtimes for Python

License Build Status

Give it a try today

To use as a docker action using python 3

wsk action update myAction myAction.py --docker openwhisk/python3action:1.0.2

Replace python3action with python2action to use python 2.

To use on deployment that contains the rutime as a kind

To use as a kind action using python 3

wsk action update myAction myAction.py --kind python:3

Replace python:3 with python:2 to use python 2.

Python 3 AI Action

This action enables developers to create AI Services with OpenWhisk. It comes with preinstalled libraries useful for running machine learning and deep learning inferences. See more about python3aiaction.

Local development

./gradlew core:pythonAction:distDocker

This will produce the image whisk/python3action

Build and Push image

docker login
./gradlew core:pythonAction:distDocker -PdockerImagePrefix=$prefix-user -PdockerRegistry=docker.io

Replace core:pythonAction with core:python2Action to build python 2 instead.

Deploy OpenWhisk using ansible environment that contains the kind python:3 and python:2 Assuming you have OpenWhisk already deploy locally and OPENWHISK_HOME pointing to root directory of OpenWhisk core repository.

Set ROOTDIR to the root directory of this repository.

Redeploy OpenWhisk

cd $OPENWHISK_HOME/ansible
ANSIBLE_CMD="ansible-playbook -i ${ROOTDIR}/ansible/environments/local"
$ANSIBLE_CMD setup.yml
$ANSIBLE_CMD couchdb.yml
$ANSIBLE_CMD initdb.yml
$ANSIBLE_CMD wipe.yml
$ANSIBLE_CMD openwhisk.yml

Or you can use wskdev and create a soft link to the target ansible environment, for example:

ln -s ${ROOTDIR}/ansible/environments/local ${OPENWHISK_HOME}/ansible/environments/local-python
wskdev fresh -t local-python

Use the docker commands to tag the image and push it into your own Docker Hub account

docker tag whisk/python3action $user_prefix/python3action
docker push $user_prefix/python3action

Then create the action using your image from dockerhub

wsk action update myAction myAction.py --docker $user_prefix/python3action

The $user_prefix is usually your dockerhub user id. Replace python3action with python2action to use python 2

Testing

Install dependencies from the root directory on $OPENWHISK_HOME repository

./gradlew install

Using gradle for the ActionContainer tests you need to use a proxy if running on Mac, if Linux then don't use proxy options You can pass the flags -Dhttp.proxyHost=localhost -Dhttp.proxyPort=3128 directly in gradle command. Or save in your $HOME/.gradle/gradle.properties

systemProp.http.proxyHost=localhost
systemProp.http.proxyPort=3128

Using gradle to run all tests

./gradlew :tests:test

Using gradle to run some tests

./gradlew :tests:test --tests *ActionContainerTests*

Using IntelliJ:

  • Import project as gradle project.
  • Make sure working directory is root of the project/repo
  • Add the following Java VM properties in ScalaTests Run Configuration, easiest is to change the Defaults for all ScalaTests to use this VM properties
-Dhttp.proxyHost=localhost
-Dhttp.proxyPort=3128

Disclaimer

Apache OpenWhisk Runtime Python is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by the Apache Incubator. Incubation is required of all newly accepted projects until a further review indicates that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. While incubation status is not necessarily a reflection of the completeness or stability of the code, it does indicate that the project has yet to be fully endorsed by the ASF.

You can’t perform that action at this time.