stackrox
The StackRox Kubernetes Security Platform performs a risk analysis of the container environment, delivers visibility and runtime alerts, and provides recommendations to proactively improve security by hardening the environment.
Top Related Projects
Find vulnerabilities, misconfigurations, secrets, SBOM in containers, Kubernetes, code repositories, clouds and more
Cloud Native Runtime Security
Open Policy Agent (OPA) is an open source, general-purpose policy engine.
A vulnerability scanner for container images and filesystems
Vulnerability Static Analysis for Containers
Detect compliance and security violations across Infrastructure as Code to mitigate risk before provisioning cloud native infrastructure.
Quick Overview
StackRox is an open-source Kubernetes-native security platform that helps organizations secure their containerized applications and infrastructure. It provides continuous monitoring, vulnerability management, and compliance enforcement for Kubernetes environments, enabling users to detect and mitigate security risks throughout the container lifecycle.
Pros
- Comprehensive security features tailored for Kubernetes environments
- Real-time threat detection and policy enforcement
- Integration with popular CI/CD tools and container registries
- Extensive compliance reporting and audit capabilities
Cons
- Steep learning curve for users new to Kubernetes security
- Resource-intensive for large-scale deployments
- Limited support for non-Kubernetes container orchestration platforms
- Some advanced features may require a paid enterprise license
Getting Started
To get started with StackRox, follow these steps:
-
Install Helm if not already installed:
curl https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3 | bash
-
Add the StackRox Helm repository:
helm repo add stackrox https://charts.stackrox.io helm repo update
-
Install StackRox using Helm:
helm install stackrox stackrox/stackrox-central-services \ --namespace stackrox \ --create-namespace \ --set central.adminPassword=<your-admin-password>
-
Access the StackRox Central UI by port-forwarding:
kubectl -n stackrox port-forward svc/central 8443:443
-
Open a web browser and navigate to
https://localhost:8443
to access the StackRox dashboard.
Note: This is a basic installation. For production environments, additional configuration and security measures are recommended. Refer to the official documentation for more detailed setup instructions and best practices.
Competitor Comparisons
Find vulnerabilities, misconfigurations, secrets, SBOM in containers, Kubernetes, code repositories, clouds and more
Pros of Trivy
- Lightweight and easy to integrate into CI/CD pipelines
- Supports scanning of multiple targets (containers, filesystems, git repositories)
- Extensive vulnerability database with frequent updates
Cons of Trivy
- Limited runtime security features compared to StackRox
- Less comprehensive Kubernetes-specific security controls
- Fewer advanced policy management capabilities
Code Comparison
StackRox example (Kubernetes YAML):
apiVersion: platform.stackrox.io/v1alpha1
kind: Policy
metadata:
name: example-policy
spec:
severity: HIGH_SEVERITY
categories:
- Vulnerability Management
Trivy example (CLI command):
trivy image --severity HIGH,CRITICAL myapp:latest
Both tools offer vulnerability scanning, but StackRox provides a more comprehensive Kubernetes-native approach with advanced policy management, while Trivy focuses on simplicity and ease of use for various scanning targets.
Cloud Native Runtime Security
Pros of Falco
- Lightweight and efficient runtime security tool with minimal performance impact
- Extensive out-of-the-box rules for detecting various security threats
- Strong community support and regular updates
Cons of Falco
- Limited built-in visualization and reporting capabilities
- Steeper learning curve for creating custom rules and integrations
Code Comparison
Falco rule example:
- rule: Unauthorized Process
desc: Detect unauthorized process execution
condition: spawned_process and not proc.name in (allowed_processes)
output: "Unauthorized process %proc.name started"
priority: WARNING
StackRox policy example:
- name: Unauthorized Process
description: Detect unauthorized process execution
criteria:
- field: Process Name
op: NOT_IN
values: ${allowed_processes}
actions:
- ALERT
Both projects focus on container and Kubernetes security, but StackRox offers a more comprehensive platform with additional features like vulnerability management and compliance checks. Falco excels in runtime security and system-level monitoring, while StackRox provides a broader set of security capabilities across the container lifecycle.
Open Policy Agent (OPA) is an open source, general-purpose policy engine.
Pros of OPA
- More versatile and general-purpose policy engine, applicable to various domains beyond Kubernetes
- Larger community and ecosystem with extensive documentation and integrations
- Lightweight and easy to embed in applications or services
Cons of OPA
- Requires more setup and configuration for Kubernetes-specific use cases
- Less out-of-the-box functionality for container security and compliance
- Steeper learning curve for writing and managing complex policies
Code Comparison
StackRox policy example:
- name: Ensure root user is not used
disabled: false
categories:
- Security Best Practices
fields:
- User
resourceTypes:
- Deployment
OPA policy example:
package kubernetes.admission
deny[msg] {
input.request.kind.kind == "Deployment"
container := input.request.object.spec.template.spec.containers[_]
container.securityContext.runAsUser == 0
msg := "Running as root is not allowed"
}
Both examples demonstrate policy definitions, but StackRox uses a YAML-based format specific to its platform, while OPA uses Rego, a more flexible policy language that can be applied to various use cases beyond Kubernetes.
A vulnerability scanner for container images and filesystems
Pros of Grype
- Lightweight and focused solely on vulnerability scanning
- Faster scanning and lower resource usage
- Easier to integrate into CI/CD pipelines due to simplicity
Cons of Grype
- Limited to vulnerability scanning, lacking broader security features
- Less comprehensive threat detection compared to full security platforms
- Requires additional tools for complete container security
Code Comparison
Grype (scanning a container image):
grype alpine:latest
StackRox (deploying the sensor):
apiVersion: apps/v1
kind: DaemonSet
metadata:
name: stackrox-sensor
namespace: stackrox
spec:
selector:
matchLabels:
app: stackrox-sensor
Summary
Grype is a focused vulnerability scanner for containers and filesystems, while StackRox is a comprehensive Kubernetes-native security platform. Grype excels in simplicity and speed for vulnerability detection, making it ideal for integration into CI/CD pipelines. However, it lacks the broader security features offered by StackRox, such as runtime threat detection, network segmentation, and compliance management.
StackRox provides a more holistic approach to container and Kubernetes security but requires more resources and setup. It offers advanced features like risk profiling and automated policy enforcement, which are not available in Grype.
Choose Grype for quick and efficient vulnerability scanning, especially in CI/CD workflows. Opt for StackRox when a full-featured Kubernetes security platform is needed, covering vulnerability management, threat detection, and compliance in a single solution.
Vulnerability Static Analysis for Containers
Pros of Clair
- Lightweight and focused specifically on container vulnerability scanning
- Integrates well with container registries, especially Quay
- Provides a RESTful API for easy integration with other tools
Cons of Clair
- Limited to vulnerability scanning, lacking broader security features
- Requires additional setup for comprehensive container security
- May have slower update cycles for vulnerability databases
Code Comparison
StackRox (Golang):
func (s *Scanner) ScanImage(ctx context.Context, image string) (*v1.ImageVulnerabilities, error) {
// Implementation for scanning images
}
Clair (Golang):
func Analyze(image *docker.Image) ([]Vulnerability, error) {
// Implementation for analyzing images
}
Both projects use Golang and provide functions for scanning container images. StackRox's approach seems more context-aware with the use of context.Context
, while Clair's function appears simpler but may lack some advanced features.
StackRox offers a more comprehensive security platform, including runtime security and compliance, while Clair focuses solely on vulnerability scanning. StackRox may be better suited for enterprises requiring a full-featured security solution, whereas Clair is ideal for projects needing a lightweight, dedicated vulnerability scanner.
Detect compliance and security violations across Infrastructure as Code to mitigate risk before provisioning cloud native infrastructure.
Pros of Terrascan
- Broader scope: Supports multiple IaC tools (Terraform, Kubernetes, Helm, Kustomize, Dockerfiles)
- Easier integration: Offers CLI, API, and CI/CD plugins for flexible usage
- Active community: More frequent updates and contributions
Cons of Terrascan
- Less comprehensive: Focuses primarily on security and compliance scanning
- Limited runtime protection: Lacks real-time threat detection and response capabilities
Code Comparison
Terrascan (Go):
func (e *Engine) Init(policyPath string, policyType policy.Type, iacType iacProvider.IacType) error {
// Initialize policy engine
e.policyPath = policyPath
e.policyType = policyType
e.iacType = iacType
return e.loadPolicies()
}
StackRox (Go):
func (s *Scanner) ScanImage(ctx context.Context, image string) (*v1.ImageScan, error) {
// Perform image scanning
scanResult, err := s.scanner.ScanImage(ctx, image)
if err != nil {
return nil, errors.Wrap(err, "scanning image")
}
return scanResult, nil
}
Both projects use Go and focus on security, but Terrascan is more oriented towards IaC scanning, while StackRox provides broader container security features.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
Table of Contents
- StackRox Kubernetes Security Platform
StackRox Kubernetes Security Platform
The StackRox Kubernetes Security Platform performs a risk analysis of the container environment, delivers visibility and runtime alerts, and provides recommendations to proactively improve security by hardening the environment. StackRox integrates with every stage of container lifecycle: build, deploy and runtime.
The StackRox Kubernetes Security platform is built on the foundation of the product formerly known as Prevent, which itself was called Mitigate and Apollo. You may find references to these previous names in code or documentation.
Community
You can reach out to us through Slack (#stackrox). For alternative ways, stop by our Community Hub stackrox.io.
For event updates, blogs and other resources follow the StackRox community site at stackrox.io.
For the StackRox Code of Conduct.
To report a vulnerability or bug.
Deploying StackRox
Quick Installation using Helm
StackRox offers quick installation via Helm Charts. Follow the Helm Installation Guide to get helm
CLI on your system.
Then run the helm quick installation script or proceed to section Manual Installation using Helm for configuration options.
Install StackRox via Helm Installation Script
/bin/bash <(curl -fsSL https://raw.githubusercontent.com/stackrox/stackrox/master/scripts/quick-helm-install.sh)
A default deployment of StackRox has certain CPU and memory requests and may fail on small (e.g. development) clusters if sufficient resources are not available. You may use the --small
command-line option in order to install StackRox on smaller clusters with limited resources. Using this option is not recommended for production deployments.
/bin/bash <(curl -fsSL https://raw.githubusercontent.com/stackrox/stackrox/master/scripts/quick-helm-install.sh) --small
The script adds the StackRox helm repository, generates an admin password, installs stackrox-central-services, creates an init bundle for provisioning stackrox-secured-cluster-services, and finally installs stackrox-secured-cluster-services on the same cluster.
Finally, the script will automatically open the browser and log you into StackRox. A certificate warning may be displayed since the certificate is self-signed. See the Accessing the StackRox User Interface (UI) section to read more about the warnings. After authenticating you can access the dashboard using https://localhost:8000/main/dashboard.
Manual Installation using Helm
StackRox offers quick installation via Helm Charts. Follow the Helm Installation Guide to get the helm
CLI on your system.
Deploying using Helm consists of 4 steps
- Add the StackRox repository to Helm
- Launch StackRox Central Services using helm
- Create a cluster configuration and a service identity (init bundle)
- Deploy the StackRox Secured Cluster Services using that configuration and those credentials (this step can be done multiple times to add more clusters to the StackRox Central Service)
Install StackRox Central Services
Default Central Installation
First, the StackRox Central Services will be added to your Kubernetes cluster. This includes the UI and Scanner. To start, add the stackrox/helm-charts/opensource repository to Helm.
helm repo add stackrox https://raw.githubusercontent.com/stackrox/helm-charts/main/opensource/
To see all available Helm charts in the repo run (you may add the option --devel
to show non-release builds as well)
helm search repo stackrox
To install stackrox-central-services, you will need a secure password. This password will be needed later for UI login and when creating an init bundle.
ROX_ADMIN_PASSWORD="$(openssl rand -base64 20 | tr -d '/=+')"
From here, you can install stackrox-central-services to get Central and Scanner components deployed on your cluster. Note that you need only one deployed instance of stackrox-central-services even if you plan to secure multiple clusters.
helm upgrade --install -n stackrox --create-namespace stackrox-central-services \
stackrox/stackrox-central-services \
--set central.adminPassword.value="${ROX_ADMIN_PASSWORD}"
--set central.persistence.none="true"
Install Central in Clusters With Limited Resources
If you're deploying StackRox on nodes with limited resources such as a local development cluster, run the following command to reduce StackRox resource requirements. Keep in mind that these reduced resource settings are not suited for a production setup.
helm upgrade -n stackrox stackrox-central-services stackrox/stackrox-central-services \
--set central.resources.requests.memory=1Gi \
--set central.resources.requests.cpu=1 \
--set central.resources.limits.memory=4Gi \
--set central.resources.limits.cpu=1 \
--set central.db.resources.requests.memory=1Gi \
--set central.db.resources.requests.cpu=500m \
--set central.db.resources.limits.memory=4Gi \
--set central.db.resources.limits.cpu=1 \
--set scanner.autoscaling.disable=true \
--set scanner.replicas=1 \
--set scanner.resources.requests.memory=500Mi \
--set scanner.resources.requests.cpu=500m \
--set scanner.resources.limits.memory=2500Mi \
--set scanner.resources.limits.cpu=2000m \
--set central.persistence.none="true"
Install StackRox Secured Cluster Services
Default Secured Cluster Installation
Next, the secured cluster component will need to be deployed to collect information on from the Kubernetes nodes.
Generate an init bundle containing initialization secrets. The init bundle will be saved in stackrox-init-bundle.yaml
, and you will use it to provision secured clusters as shown below.
echo "$ROX_ADMIN_PASSWORD" | \
kubectl -n stackrox exec -i deploy/central -- bash -c 'ROX_ADMIN_PASSWORD=$(cat) roxctl --insecure-skip-tls-verify \
central init-bundles generate stackrox-init-bundle --output -' > stackrox-init-bundle.yaml
Set a meaningful cluster name for your secured cluster in the CLUSTER_NAME
shell variable. The cluster will be identified by this name in the clusters list of the StackRox UI.
CLUSTER_NAME="my-secured-cluster"
Then install stackrox-secured-cluster-services (with the init bundle you generated earlier) using this command:
helm upgrade --install --create-namespace -n stackrox stackrox-secured-cluster-services stackrox/stackrox-secured-cluster-services \
-f simon-test-cluster-init-bundle.yaml \
--set clusterName="$CLUSTER_NAME" \
--set centralEndpoint="central.stackrox.svc:443"
When deploying stackrox-secured-cluster-services on a different cluster than the one where stackrox-central-services is deployed, you will also need to specify the endpoint (address and port number) of Central via --set centralEndpoint=<endpoint_of_central_service>
command-line argument.
Install Secured Cluster with Limited Resources
When deploying StackRox Secured Cluster Services on a small node, you can install with additional options. This should reduce stackrox-secured-cluster-services resource requirements. Keep in mind that these reduced resource settings are not recommended for a production setup.
helm install -n stackrox stackrox-secured-cluster-services stackrox/stackrox-secured-cluster-services \
-f stackrox-init-bundle.yaml \
--set clusterName="$CLUSTER_NAME" \
--set centralEndpoint="central.stackrox.svc:443" \
--set sensor.resources.requests.memory=500Mi \
--set sensor.resources.requests.cpu=500m \
--set sensor.resources.limits.memory=500Mi \
--set sensor.resources.limits.cpu=500m
Additional information about Helm charts
To further customize your Helm installation consult these documents:
Installation via Scripts
The deploy
script will:
- Launch StackRox Central Services
- Create a cluster configuration and a service identity
- Deploy the StackRox Secured Cluster Services using that configuration and those credentials
You can set the environment variable MAIN_IMAGE_TAG
in your shell to
ensure that you get the version you want.
If you check out a commit, the scripts will launch the image corresponding to that commit by default. The image will be pulled if needed.
Further steps are orchestrator specific.
Kubernetes Distributions (EKS, AKS, GKE)
Click to expand
Follow the guide below to quickly deploy a specific version of StackRox to your Kubernetes cluster in the stackrox
namespace. If you want to install a specific version, make sure to define/set it in MAIN_IMAGE_TAG
, otherwise it will install the latest nightly build.
Run the following in your working directory of choice:
git clone git@github.com:stackrox/stackrox.git
cd stackrox
MAIN_IMAGE_TAG=VERSION_TO_USE ./deploy/deploy.sh
After a few minutes, all resources should be deployed.
Credentials for the 'admin' user can be found in the ./deploy/k8s/central-deploy/password
file.
Note: While the password file is stored in plaintext on your local filesystem, the Kubernetes Secret StackRox uses is encrypted, and you will not be able to alter the secret at runtime. If you lose the password, you will have to redeploy central.
OpenShift
Click to Expand
Before deploying on OpenShift, ensure that you have the oc - OpenShift Command Line installed.
Follow the guide below to quickly deploy a specific version of StackRox to your OpenShift cluster in the stackrox
namespace. Make sure to add the most recent tag to the MAIN_IMAGE_TAG
variable.
Run the following in your working directory of choice:
git clone git@github.com:stackrox/stackrox.git
cd stackrox
MAIN_IMAGE_TAG=VERSION_TO_USE ./deploy/deploy.sh
After a few minutes, all resources should be deployed. The process will complete with this message.
Credentials for the 'admin' user can be found in the ./deploy/openshift/central-deploy/password
file.
Note: While the password file is stored in plaintext on your local filesystem, the Kubernetes Secret StackRox uses is encrypted, and you will not be able to alter the secret at runtime. If you loose the password, you will have to redeploy central.
Docker Desktop, Colima, or minikube
Click to Expand
Run the following in your working directory of choice:
git clone git@github.com:stackrox/stackrox.git
cd stackrox
MAIN_IMAGE_TAG=latest ./deploy/deploy-local.sh
After a few minutes, all resources should be deployed.
Credentials for the 'admin' user can be found in the ./deploy/k8s/deploy-local/password
file.
Accessing the StackRox User Interface (UI)
Click to expand
After the deployment has completed (Helm or script install) a port-forward should exist, so you can connect to https://localhost:8000/. Run the following
kubectl port-forward -n 'stackrox' svc/central "8000:443"
Then go to https://localhost:8000/ in your web browser.
Username = The default user is admin
Password (Helm) = The password is in $ROX_ADMIN_PASSWORD
after a manual installation, or printed at the end of the quick installation script.
Password (Script) = The password will be located in the /deploy/<orchestrator>/central-deploy/password.txt
folder for the script install.
Development
-
UI Dev Docs: Refer to ui/README.md
-
E2E Dev Docs: Refer to qa-tests-backend/README.md
-
Pull request guidelines: contributing.md
-
Go coding style guide: go-coding-style.md
Quickstart
Build Tooling
The following tools are necessary to test code and build image(s):
Click to expand
- Make
- Go
- Various Go linters that can be installed using
make reinstall-dev-tools
. - UI build tooling as specified in ui/README.md.
- Docker
- Note: Docker Desktop now requires a paid subscription for larger, enterprise companies.
- Some StackRox devs recommend Colima
- Xcode command line tools (macOS only)
- Bats is used to run certain shell tests.
You can obtain it with
brew install bats
ornpm install -g bats
. - oc OpenShift cli tool
- shellcheck for shell scripts linting.
Xcode - macOS Only
Usually you would have these already installed by brew. However, if you get an error when building the golang x/tools, try first making sure the EULA is agreed by:
- starting Xcode
- building a new blank app project
- starting the blank project app in the emulator
- close both the emulator and the Xcode, then
- run the following commands:
xcode-select --install
sudo xcode-select --switch /Library/Developer/CommandLineTools # Enable command line tools
sudo xcode-select -s /Applications/Xcode.app/Contents/Developer
For more info, see https://github.com/nodejs/node-gyp/issues/569
Clone StackRox
Click to expand
# Create a GOPATH: this is the location of your Go "workspace".
# (Note that it is not â and must not â be the same as the path Go is installed to.)
# The default is to have it in ~/go/, or ~/development, but anything you prefer goes.
# Whatever you decide, create the directory, set GOPATH, and update PATH:
export GOPATH=$HOME/go # Change this if you choose to use a different workspace.
export PATH=$PATH:$GOPATH/bin
# You probably want to permanently set these by adding the following commands to your shell
# configuration (e.g. ~/.bash_profile)
cd $GOPATH
mkdir -p bin pkg
mkdir -p src/github.com/stackrox
cd src/github.com/stackrox
git clone git@github.com:stackrox/stackrox.git
Local Development
Click to expand
To sweeten your experience, install the workflow scripts beforehand.
$ cd $GOPATH/src/github.com/stackrox/stackrox
$ make install-dev-tools
$ make image
Now, you need to bring up a Kubernetes cluster yourself before proceeding.
Development can either happen in GCP or locally with
Docker Desktop, Colima, minikube.
Note that Docker Desktop and Colima are more suited for macOS development, because the cluster will have access to images built with make image
locally without additional configuration. Also, Collector has better support for these than minikube where drivers may not be available.
# To keep the StackRox Central's Postgres DB state between database upgrades and restarts, set:
$ export STORAGE=pvc
# To save time on rebuilds by skipping UI builds, set:
$ export SKIP_UI_BUILD=1
# To save time on rebuilds by skipping CLI builds, set:
$ export SKIP_CLI_BUILD=1
# When you deploy locally make sure your kube context points to the desired kubernetes cluster,
# for example Docker Desktop.
# To check the current context you can call a workflow script:
$ roxkubectx
# To deploy locally, call:
$ ./deploy/deploy-local.sh
# Now you can access StackRox dashboard at https://localhost:8000
# or simply call another workflow script:
$ logmein
See Installation via Scripts for further reading. To read more about the environment variables, consult deploy/README.md.
Common Makefile Targets
Click to expand
# Build image, this will create `stackrox/main` with a tag defined by `make tag`.
$ make image
# Compile all binaries
$ make main-build-dockerized
# Displays the docker image tag which would be generated
$ make tag
# Note: there are integration tests in some components, and we currently
# run those manually. They will be re-enabled at some point.
$ make test
# Apply and check style standards in Go and JavaScript
$ make style
# enable pre-commit hooks for style checks
$ make init-githooks
# Compile and restart only central
$ make fast-central
# Compile only sensor
$ make fast-sensor
# Only compile protobuf
$ make proto-generated-srcs
Productivity
Click to expand
The workflow repository contains some helper scripts
which support our development workflow. Explore more commands with roxhelp --list-all
.
# Change directory to rox root
$ cdrox
# Handy curl shortcut for your StackRox central instance
# Uses https://localhost:8000 by default or ROX_BASE_URL env variable
# Also uses the admin credentials from your last deployment via deploy.sh
$ roxcurl /v1/metadata
# Run quickstyle checks, faster than stackrox's "make style"
$ quickstyle
# The workflow repository includes some tools for supporting
# working with multiple inter-dependent branches.
# Examples:
$ smart-branch <branch-name> # create new branch
... work on branch...
$ smart-rebase # rebase from parent branch
... continue working on branch...
$ smart-diff # check diff relative to parent branch
... git push, etc.
GoLand Configuration
Click to expand
If you're using GoLand for development, the following can help improve the experience.
Make sure the Protocol Buffers
plugin is installed. The plugin comes installed by default in GoLand.
If it isn't, use Help | Find Action...
, type Plugins
and hit enter, then switch to Marketplace
, type its name and install the plugin.
This plugin does not know where to look for .proto
imports by default in GoLand therefore you need to explicitly
configure paths for this plugin. See https://github.com/jvolkman/intellij-protobuf-editor#path-settings.
- Go to
GoLand | Preferences | Languages & Frameworks | Protocol Buffers
. - Uncheck
Configure automatically
. - Click on
+
button, navigate and select./proto
directory in the root of the repo. - Optionally, also add
$HOME/go/pkg/mod/github.com/gogo/googleapis@1.1.0
and$HOME/go/pkg/mod/github.com/gogo/protobuf@v1.3.1/
. - To verify: use menu
Navigate | File...
type any.proto
file name, e.g.alert_service.proto
, and check that all import strings are shown green, not red.
Running sql_integration tests
Click to expand
Go tests annotated with //go:build sql_integration
require a PostgreSQL server listening on port 5432.
Due to how authentication is set up in code, it is the easiest to start Postgres in a container like this:
$ docker run --rm --env POSTGRES_USER="$USER" --env POSTGRES_HOST_AUTH_METHOD=trust --publish 5432:5432 docker.io/library/postgres:13
With that running in the background, sql_integration
tests can be triggered from IDE or command-line.
Debugging
Click to expand
Kubernetes debugger setup
With GoLand, you can naturally use breakpoints and the debugger when running unit tests in IDE.
If you would like to debug local or even remote deployment, follow the procedure below.
- Create debug build locally by exporting
DEBUG_BUILD=yes
:
Alternatively, debug build will also be created when the branch name contains$ DEBUG_BUILD=yes make image
-debug
substring. This works locally withmake image
and in CI. - Deploy the image using instructions from this README file. Works both with
deploy-local.sh
anddeploy.sh
. - Start the debugger (and port forwarding) in the target pod using
roxdebug
command fromworkflow
repo.# For Central $ roxdebug # For Sensor $ roxdebug deploy/sensor # See usage help $ roxdebug --help
- Configure GoLand for remote debugging (should be done only once):
- Open
Run | Edit Configurations â¦
, click on the+
icon to add new configuration, chooseGo Remote
template. - Choose
Host:
localhost
andPort:
40000
. Give this configuration some name. - Select
On disconnect:
Leave it running
(this prevents GoLand forgetting breakpoints on reconnect).
- Open
- Attach GoLand to debugging port: select
Run | Debugâ¦
and choose configuration you've created. If all done right, you should seeConnected
message in theDebug | Debugger | Variables
window at the lower part of the screen. - Set some code breakpoints, trigger corresponding actions and happy debugging!
See Debugging go code running in Kubernetes for more info.
Generating Portable Installers
Kubernetes
docker run -i --rm quay.io/stackrox-io/main:<tag> central generate interactive > k8s.zip
This will run you through an installer and generate a k8s.zip
file.
unzip k8s.zip -d k8s
bash k8s/central.sh
Now Central has been deployed. Use the UI to deploy Sensor.
OpenShift
Note: If using a host mount, you need to allow the container to access it by using
sudo chcon -Rt svirt_sandbox_file_t <full volume path>
Take the image-setup.sh script from this repo and run it to do the pull/push to local OpenShift registry. This is a prerequisite for every new cluster.
bash image-setup.sh
docker run -i --rm quay.io/stackrox-io/main:<tag> central generate interactive > openshift.zip
This will run you through an installer and generate a openshift.zip
file.
unzip openshift.zip -d openshift
bash openshift/central.sh
Dependencies and Recommendations for Running StackRox
Click to Expand
The following information has been gathered to help with the installation and operation of the open source StackRox project. These recommendations were developed for the Red Hat Advanced Cluster Security for Kubernetes product and have not been tested with the upstream StackRox project.
Recommended Kubernetes Distributions
The Kubernetes Platforms that StackRox has been deployed onto with minimal issues are listed below.
- Red Hat OpenShift Dedicated (OSD)
- Azure Red Hat OpenShift (ARO)
- Red Hat OpenShift Service on AWS (ROSA)
- Amazon Elastic Kubernetes Service (EKS)
- Google Kubernetes Engine (GKE)
- Microsoft Azure Kubernetes Service (AKS)
If you deploy into a Kubernetes distribution other than the ones listed above you may encounter issues.
Recommended Operating Systems
StackRox is known to work on the recent versions of the following operating systems.
- Ubuntu
- Debian
- Red Hat Enterprise Linux (RHEL)
- CentOS
- Fedora CoreOS
- Flatcar Container Linux
- Google COS
- Amazon Linux
- Garden Linux
Recommended Web Browsers
The following table lists the browsers that can view the StackRox web user interface.
- Google Chrome 88.0 (64-bit)
- Microsoft Internet Explorer Edge
- Version 44 and later (Windows)
- Version 81 (Official build) (64-bit)
- Safari on MacOS (Mojave) - Version 14.0
- Mozilla Firefox Version 82.0.2 (64-bit)
Top Related Projects
Find vulnerabilities, misconfigurations, secrets, SBOM in containers, Kubernetes, code repositories, clouds and more
Cloud Native Runtime Security
Open Policy Agent (OPA) is an open source, general-purpose policy engine.
A vulnerability scanner for container images and filesystems
Vulnerability Static Analysis for Containers
Detect compliance and security violations across Infrastructure as Code to mitigate risk before provisioning cloud native infrastructure.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot