Logs#
Server Log#
Package Manager's default server logging outputs are STDOUT
and /var/log/rstudio/rstudio-pm/rstudio-pm.log
. The log file is owned by rstudio-pm
with permissions 0600
.
If logrotate
is available when Posit Package Manager is installed, a logrotate
configuration will be installed. The default configuration is to rotate the log file daily. The old log file will be stored alongside the original with a numeric extension, .1
, .2
, etc. The rotated log files are compressed after one day. The .1
log file is retained uncompressed, but older logs are compressed. Most systems use gzip
for compression, giving log files with extensions like .2.gz
, .3.gz
. Logs will be maintained for 30 days.
The manual for logrotate
has more information.
Note
Please note that if the logging output file of Package Manager is changed, logrotate
will also need to be reconfigured.
Log levels, including debug logging levels, are controlled via the Logging.SystemLogLevel
variable. This section is documented in the configuration appendix.
[Logging]
SystemLog = STDOUT,/var/log/rstudio/rstudio-pm/rstudio-pm.log
SystemLogLevel = INFO
SystemLogFormat = JSON
Additionally, the system log level can be configured via the admin CLI command rspm log level --level=[level]
command.
Package Service Log#
Package Manager can log information about serving source and binary packages. To enable the package service log, define the Server.ServiceLog
configuration property.
[Server]
ServiceLog = "/var/log/rstudio/rstudio-pm/rstudio-pm.service.log"
The package service log file is owned by rstudio-pm
with permissions 0600
. The log file is stored in JSON format, with each row being a valid JSON object.
Package Service Log Properties#
Each row of the package service log is a valid JSON object. The following properties may be included.
time
-
A timestamp that identifies when the request was initiated.
-
Type: string
-
Appears: all logs
name
-
The name of the package that was requested.
-
Type: string
-
Appears: all logs
version
-
The version of the package that was requested.
-
Type: string
-
Appears: all logs
class
-
Set to one of the following
-
current
- A current source package request.
-
archived
- An archived source package request.
-
binary_win
- A Windows binary package request.
-
binary_mac
- A macOS binary package request.
-
Type: string
-
Appears: all logs
source
-
Set to the source name for the current package request. This is useful for determining which source a package originates from, particularly when a repo contains multiple sources.
-
Type: string
-
Appears: all logs
src_type
-
Set to the source type for the current package request. This is useful for determining which source type a package originates from.
-
Type: string
-
Appears: all logs
lic_type
-
An array of the SPDX license identifiers associated with the current package request. If the package license cannot be associated with a standardized license identifier in the SPDX License List,
Unknown
will be returned. -
Type: string array
-
Appears: all logs
type
-
Indicates one of the following request types
-
source_archived
- The request is for an archived package source.
-
source_current
- The request is for a current package source.
-
binary_archived
- The request is for an archived package binary.
-
binary_current
- The request is for a current package binary.
-
Type: string
-
Appears: all logs
distro
-
For package binary requests, indicates the distro requested. When R is configured to use Linux binaries, the distro is the URL segment that directly follows
__linux__/
. On Windows, the distro indicates the R version, e.g.,3.5-win
. -
Type: string
-
Appears: binary requests only
r_version
-
For package binary requests, indicates the R version requested. The R version is indicated in the
User-Agent
header value. -
Type: string
-
Appears: binary requests only
match_type
-
For package binary requests, indicates one of the following match types.
-
best
- A best-matching R version was calculated based on theUser-Agent
header value.
-
Type: string
-
Appears: binary requests only
failed_service
-
The presence of this property indicates a service failure. If the log line includes a
message
property ofok
, then afailed_service
property indicates that a package binary request was unsuccessful, but the service was able to successfully fall back to serving the package source. However, if the log line'smessage
property includes an error message, then the request failed. -
Service failure values include:
-
service_error_ash
- Failure while calculating the unique signature (ASH) for a package binary.
-
service_error_fetch
- Failure while fetching package binary or source files from storage.
-
service_error_blocked
- Failure when attempting to download a package that is blocked through the security rules.
-
Type: string
-
Appears: failed and source fallback requests (service failure related)
failed_ua
-
For package binary requests, the presence of this property property indicates a User-Agent failure. User-Agent failures include:
-
ua_error_none
- NoUser-Agent
header was found.
-
ua_error_unsupported_os
- TheUser-Agent
header value indicates an OS that is not supported.
-
ua_error_no_r
- TheUser-Agent
header value does not indicate the R version.
-
ua_error_distro_mismatch
- The OS indicated by theUser-Agent
header value does not match the OS for the distro.
-
Type: string
-
Appears:
User-Agent
-related source fallback requests user_agent
-
For User-Agent failures, the
User-Agent
header value is included for reference. -
Type: string
-
Appears:
User-Agent
-related source fallback requests failed_match
-
For package binary requests, the presence of this property indicates a failure related to calculating a best-matching R version. Values include:
-
match_error_no_best_match
- No matching R version was found.
-
Type: string
-
Appears: Match-related source fallback requests
error
-
For service failures that result in falling back to serving source, an
error
property may be included to indicate an error message associated with the service failure. -
Type: string
-
Appears: source fallback requests (service failure related)
message
-
For requests ending in failure, the error message is indicated by the
message
property. All other requests, including requests for binaries that successfully fall back to source due to one of the above failure modes, will return a value ofok
. -
Type: string
-
Appears: all logs
Package Service Log Examples#
Below are examples of typical package service logs.
-
Successfully serving a current package binary for a Linux distribution.
-
A current package binary was requested, but was not available to download. Package Manager automatically fell back to serving the package source, which succeeded.
{ "time": 1563907544, "name": "plumber", "version": "0.4.6", "class": "current", "type": "binary_current", "distro": "rhel9", "r_version": "4.3.1", "match_type": "best", "error": "DownloadBinaryEtagRunner: file not found: https://rspm-sync.rstudio.com/bin/4.3-rhel9/e3f8ab6d0bd9f83cb787b4f7472d60d98f247f64ea2c8a32aff68be6abbde5cf.tar.gz", "failed_service": "service_error_fetch", "message": "ok" }
-
A current package binary was requested, but the R version was not supported by Package Manager. Package Manager automatically fell back to serving the package source, which succeeded.
-
A current package binary was requested, but the
User-Agent
header did not indicate an R version. Package Manager automatically fell back to serving the package source, which succeeded. Note that theuser_agent
property is included in this case to aid in debugging.
-
A current package binary was requested, but the
User-Agent
header indicated an unsupported OS. Package Manager automatically fell back to serving the package source, which succeeded. Note that theuser_agent
property is included in this case to aid in debugging.
-
Serving a current package source.
Access Logs#
The Package Manager HTTP access logs are located at /var/log/rstudio/rstudio-pm/rstudio-pm.access.log
. This file is owned by rstudio-pm
with permissions 0600
. Log files are stored in Apache Combined Log Format.
You can switch to the Apache Common Log Format if preferred by setting Server.AccessLogFormat = "common"
.
When Package Manager is installed, if available, the logrotate
configuration is also installed. The default configuration is to rotate the log file daily. The old log file will be compressed and stored alongside the original log file with a .1.gz
extension (then .2.gz
, etc.). Logs will maintained for 30 days.
Note
For information on the differences between the Apache Combined Log Format and the Apache Common Log Format refer to Apache's documentation here.