https://github.com/sjw7444/lambda-playwright-python
Base Docker image for running Playwright with Python on AWS Lambda
https://github.com/sjw7444/lambda-playwright-python
docker lambda playwright playwright-python
Last synced: 6 days ago
JSON representation
Base Docker image for running Playwright with Python on AWS Lambda
- Host: GitHub
- URL: https://github.com/sjw7444/lambda-playwright-python
- Owner: sjw7444
- License: mit
- Created: 2025-05-09T03:28:06.000Z (about 1 month ago)
- Default Branch: main
- Last Pushed: 2025-06-10T15:34:42.000Z (11 days ago)
- Last Synced: 2025-06-10T16:37:25.116Z (11 days ago)
- Topics: docker, lambda, playwright, playwright-python
- Language: Dockerfile
- Homepage: https://hub.docker.com/r/sjw7444/lambda-playwright-python
- Size: 20.5 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
README
# Lambda Playwright Python Base Image
[](https://github.com/sjw7444/lambda-playwright-python/actions/workflows/deploy.yml)
This repository contains a base Docker image for running Playwright with Python on AWS Lambda with ARM support. The image is optimized for serverless environments and includes all necessary dependencies for headless Chromium browser automation.
## Access the image using Docker Hub or AWS ECR
- [Docker Hub](https://hub.docker.com/r/sjw7444/lambda-playwright-python)
- [AWS ECR](https://gallery.ecr.aws/j9p6g6v0/lambda-playwright-python)## Features
- Python 3.13 support with latest performance improvements
- Playwright with headless Chromium browser
- AWS Lambda ARM64 compatibility
- Optimized for serverless environments
- Minimal dependencies for Chromium only
- Uses AWS Lambda's microdnf package manager
- Enhanced type system and better type checking
- Improved memory management and performance
- VS Code dev container support with development tools## Development Setup
### Prerequisites
- Docker
- VS Code with Remote - Containers extension
- AWS CLI (for ECR deployment)
- Python 3.13+### VS Code Dev Container
This project includes a VS Code dev container configuration that provides:
- Git for version control
- Python development tools
- All necessary VS Code extensions
- Pre-configured testing environmentTo use the dev container:
1. Open the project in VS Code
2. When prompted, click "Reopen in Container"
- Or use the Command Palette (F1) and select "Dev Containers: Reopen in Container"### Building Locally
```bash
docker build -t lambda-playwright-python .
```### Testing
```bash
pytest tests/
```## Usage as Base Image
### Pulling the Base Image
```bash
# From DockerHub
docker pull sjw7444/lambda-playwright-python:latest# From AWS ECR
aws ecr-public get-login-password --region us-east-1 | docker login --username AWS --password-stdin public.ecr.aws/j9p6g6v0/lambda-playwright-python
docker pull public.ecr.aws/j9p6g6v0/lambda-playwright-python:latest
```### Using as Base Image
Create a new Dockerfile in your project:
```dockerfile
FROM sjw7444/lambda-playwright-python:latest# Copy your Lambda function code
COPY your_lambda_function.py ${LAMBDA_TASK_ROOT}# Set the CMD to your handler
CMD [ "your_lambda_function.handler" ]
```### Example Lambda Function with Headless Chromium
```python
from playwright.sync_api import sync_playwrightdef handler(event, context):
with sync_playwright() as p:
# Launch headless Chromium
browser = p.chromium.launch(headless=True)
page = browser.new_page()
# Your automation code here
page.goto('https://example.com')
title = page.title()
browser.close()
return {'statusCode': 200, 'body': title}
```## Project Structure
```txt
.
├── Dockerfile # Base image Dockerfile (Chromium-only)
├── .devcontainer/ # VS Code dev container configuration
├── .github/ # GitHub Actions workflows
├── .vscode/ # VS Code settings and extensions
├── tests/ # Test files
└── requirements.txt # Python dependencies
```## Deployment
The base image is automatically built and deployed to both DockerHub and AWS ECR Public when changes are pushed to the main branch.
### Required Secrets
To use the deployment workflow, you need to set up the following secrets in your GitHub repository:
- `AWS_ROLE_ARN`: AWS IAM role ARN for ECR access
- `ECR_REPOSITORY`: Your ECR repository name
- `DOCKERHUB_USERNAME`: Your DockerHub username
- `DOCKERHUB_TOKEN`: Your DockerHub access token### AWS Permissions
The AWS IAM role needs the following permissions:
- `ecr-public:GetAuthorizationToken`
- `ecr-public:BatchCheckLayerAvailability`
- `ecr-public:GetRepositoryPolicy`
- `ecr-public:DescribeRepositories`
- `ecr-public:InitiateLayerUpload`
- `ecr-public:UploadLayerPart`
- `ecr-public:CompleteLayerUpload`
- `ecr-public:PutImage`## License
MIT License
## Contributing
1. Fork the repository
2. Create your feature branch
3. Commit your changes
4. Push to the branch
5. Create a new Pull Request## Security
This repository is designed to be open source. All sensitive information is stored as GitHub secrets and not committed to the repository. If you find any security issues, please report them by creating an issue.