Launching bpfman
The most basic way to deploy bpfman is to run it directly on a host system.
First bpfman needs to be built and then started.
Build bpfman
Perform the following steps to build bpfman.
If this is your first time using bpfman, follow the instructions in
Setup and Building bpfman to setup the prerequisites for building.
To avoid installing the dependencies and having to build bpfman, consider running bpfman
from a packaged release (see Run bpfman From Release Image) or
installing the bpfman RPM (see Run bpfman From RPM).
Install and Start bpfman
Run the following command to copy the bpfman CLI and bpfman-rpc binaries to /usr/sbin/ and
copy bpfman.socket and bpfman.service files to /usr/lib/systemd/system/.
This option will also enable and start the systemd services:
bpfman CLI is now in $PATH and can be used to load, attach, view and unload eBPF programs.
sudo bpfman load image --image-url quay.io/bpfman-bytecode/xdp_pass:latest \
     --programs xdp:pass --application XdpPassProgram
sudo bpfman list programs --application XdpPassProgram
 Program ID  Application     Type  Function Name  Links
 63661       XdpPassProgram  xdp   pass           (1) 1301256968
bpfman CLI is a Rust program that calls the bpfman library directly.
To view logs while running bpfman CLI commands, prepend RUST_LOG=info to each command
(see Logging for more details):
sudo RUST_LOG=info bpfman list programs
[INFO  bpfman::utils] Has CAP_BPF: true
[INFO  bpfman::utils] Has CAP_SYS_ADMIN: true
 Program ID  Application     Type        Function Name    Links
The examples (see Deploying Example eBPF Programs On Local Host)
are Go based programs, so they are building and sending RPC messages to the rust based binary
bpfman-rpc, which in turn calls the bpfman library.
To view bpfman logs for RPC based applications, including all the provided examples, use journalctl:
sudo journalctl -f -u bpfman.service -u bpfman.socket
:
  <RUN "go run -exec sudo . -iface eno3">
Aug 26 18:03:54 server-calvin bpfman-rpc[2401725]: Using a Unix socket from systemd
Aug 26 18:03:54 server-calvin bpfman-rpc[2401725]: Using inactivity timer of 15 seconds
Aug 26 18:03:54 server-calvin bpfman-rpc[2401725]: Listening on /run/bpfman-sock/bpfman.sock
Aug 26 18:03:54 server-calvin bpfman-rpc[2401725]: Has CAP_BPF: true
Aug 26 18:03:54 server-calvin bpfman-rpc[2401725]: Has CAP_SYS_ADMIN: true
Aug 26 18:03:54 server-calvin bpfman-rpc[2401725]: Starting Cosign Verifier, downloading data from Sigstore TUF repository
Aug 26 18:03:55 server-calvin bpfman-rpc[2401725]: Loading program bytecode from file: /home/$USER/src/bpfman/bpfman/examples/go-xdp-counter/bpf_x86_bpfel.o
Aug 26 18:03:57 server-calvin bpfman-rpc[2401725]: The bytecode image: quay.io/bpfman/xdp-dispatcher:latest is signed
Aug 26 18:03:57 server-calvin bpfman-rpc[2401725]: Added xdp program with name: xdp_stats and id: 53919
Aug 26 18:04:09 server-calvin bpfman-rpc[2401725]: Shutdown Unix Handler /run/bpfman-sock/bpfman.sock```
Additional Notes
To update the configuration settings associated with running bpfman as a service, edit the
service configuration files:
sudo vi /usr/lib/systemd/system/bpfman.socket
sudo vi /usr/lib/systemd/system/bpfman.service
sudo systemctl daemon-reload
If bpfman CLI or bpfman-rpc is rebuilt, the following command can be run to install the update
binaries without tearing down bpfman.
The services are automatically restarted.
To unwind all the changes, stop bpfman and remove all related files from the system, run the
following script:
Preferred Method to Start bpfman
In order to call into the bpfman Library, the calling process must be privileged.
In order to load and unload eBPF, the kernel requires a set of powerful capabilities.
Long lived privileged processes are more vulnerable to attack than short lived processes.
When bpfman-rpc is run as a systemd service, it is leveraging
socket activation.
This means that it loads a bpfman.socket and bpfman.service file.
The socket service is the long lived process, which doesn't have any special permissions.
The service that runs bpfman-rpc is only started when there is a request on the socket,
and then bpfman-rpc stops itself after an inactivity timeout.
Note
For security reasons, it is recommended to run bpfman-rpc as a systemd service when running
on a local host.
For local development, some may find it useful to run bpfman-rpc as a long lived process.
When run as a systemd service, the set of linux capabilities are limited to only the required set. If permission errors are encountered, see Linux Capabilities for help debugging.