New and changed features
New GitHub SCM repository scanning and read-only BOM
You can now integrate Black Duck with your GitHub repository, to quickly and easily gain visibility across all the repositories in GitHub, as well as the ability to add as a project version BOM in Black Duck.
You can now do the following:
- Add selected main repositories as a new project in Black Duck: This allows users to quickly view the security and policy violation of the GitHub repository.
- Run scans at will: You can trigger a scan from the Black Duck version page that is mapped to the repository, to find any new problems in your current libraries, for example to find critical zero-day vulnerabilities quickly. The result of this scan creates a lighter, read-only BOM which provides a quick overview of your repository detailing the components and licenses found, and any vulnerabilities associated to those components.
Please note that this feature is currently only supported for Hosted Black Duck customers. SCM integration utilizes a service that runs strictly within a Kubernetes environment, either native or Kubernetes in Docker (KinD). The helm charts will need to be used to install Black Duck to use this feature.
New scan auto-unmapping management page
You can now manage when scans are scheduled to be unmapped from inactive project versions. They need to meet the project version phase and inactivity time conditions, and will only be unmapped after the grace period. The Scan Auto-Unmapping page is found in Black Duck by clicking the Admin button → System Settings → Data Retention → Scan Auto-Unmapping.
New Automatic Scan Retry Header support for Black Duck Detect
A new Retry-After header has been added in the 429 response for Detect to know when
to attempt a rate limited scan again. The following properties have been added to
the blackduck-config.env
file:
BLACKDUCK_USE_QUEUE_RATE_LIMITING
: Set to true
to enable queue base rate limiting in your environment. Default value is
false
.
BLACKDUCK_INITIAL_RATE_LIMIT_DURATION_BRACKET_THRESHOLD_MINUTES
:
dictates the duration the system must be rate limiting before the system moves from
the first retry duration to the second retry duration.
BLACKDUCK_RATE_LIMIT_DURATION_THRESHOLD_BRACKET_INCREMENT_MINUTES
:
Dictates the duration that the system will stay in a rate limiting bracket before
going to the next retry duration and multiplier.
BLACKDUCK_INITIAL_RETRY_DURATION_MINUTES
: The initial duration of
the Retry-After header in the first rate limiting bracket.
BLACKDUCK_RETRY_DURATION_MULTIPLIER_MINUTES
: The amount to multiply
the Retry-After Duration by each time the system reaches a new rate limit duration
bracket.
New runtime threshold environment variable
You can now configure the threshold to determine long running jobs by adding the
following variable to your blackduck-config.env
file:
BLACKDUCK_DEFAULT_JOB_RUNTIME_THRESHOLD_HOURS
={value in hours}
The default value for this environment variable is 24 hours.
New Include Subprojects option for reports
You can now choose to include subprojects by checking the new Include Subproject checkbox in the report generation dialog box when creating the following reports:
- Notices File
- SBOM
- Version Details
Please note that this feature is enabled by default and subprojects were already included in report generation previous to this change. This feature now explicitly allows you to configure this functionality.
New Transitive Upgrade Guidance
Please note that this feature was added in Black Duck 2023.1.0 and was accidentally left out of the release notes for that version.
The simplest way to resolve security risk is to upgrade the version of the used component with fewer vulnerabilities. It is easier to do for components used as direct match. It is more difficult to mitigate or remove component vulnerabilities brought in as transitive dependencies without understanding what root direct dependency brought in that component. The goal of this feature is more simply and directly provide transitive upgrade guidance to provide a better developer experience and more clear call to action.
Enhanced Black Duck Secure Container (BDSC)
Black Duck introduces a new type of container image scan and project view to simplify managing the risk from container images. The container project can show the aggregated BOM and risk, but it also provides a way to view risk layer by layer, including separating risk from the base imagine or OS and the application layers. In addition, we've added support for viewing where and when components are added or removed in a layer.
Additionally, the Black Duck KnowledgeBase will expand its inventory to cover Docker Hub base container images and layer by layer component details to enable Black Duck to focus is scanning on the client container.
The existing Black Duck container image scanning as part of signature scanning, binary scanning, and Docker Inspector has not changed and will continue to be supported. The new container image scanning feature and project view will improve the user experience for managing risk found in containers enabling customers to manage the risk by container layer.
Please note that in order to take advantage of this feature, you must have Black Duck Secure Container (BDSC) enabled on your product registration key. Customers with a Black Duck Binary Analysis integrated subscription will have this included in their license.
Enhanced license risk aggregation - Limited customer availability
Prior to this enhancement, license risk from subprojects were not tracked or viewable within parent projects. This presented the possibility that license risk could be missed when using subproject hierarchies. Now, when you enable this feature, the License Risk displayed for a subproject in your project's BOM will be determined by the subproject's license risk and the highest license risk of its components.
Note that this feature is not general available and it not enabled by default. Enhanced license risk aggregation will be made generally available in an upcoming Black Duck release and will be enabled by default at that time.
Enhanced SBOM Import Component Visibility
You now have the ability to identify which components originated as a result of the SBOM import vs. other types of identification/scans or other imported SBOMs. In the Project Version's Source tab, you can identify the SBOM type (SPDX or CycloneDX), when the SBOM was imported, who supplied the SBOM, and the version of the tool used to create the SBOM.
Enhanced Component Versions page
The Component Versions page now more clearly displays what you are looking as far as security risk based on the scoring system priority set by System Administrator. The table now indicates if a component version has other vulnerabilities and how many that comes from another scoring system, such as CVSS v2.
Enhanced Jobs page functionality
The Processing tab of the Jobs pages will now display a warning icon next to jobs that are running longer than normal. You can also filter this page on Long Running jobs to display a list of these jobs.
In addition, new Prometheus metrics are available for users to see any jobs that are running longer than usual on the system.
Scanning hardware requirements changes
Black Duck 2023.10.0 sees a number of changes in scanning hardware requirements therefore Black Duck customers must update their environments and allocate additional hardware resources where necessary per the guidance below. Please see Black Duck Hardware Scaling Guidelines to stay up-to-date when changes are made to these recommendations.
Name | Details | |
---|---|---|
10sph | Scans/Hour: 50 SPH % Increase: 400% APIs/Hour: 2,500 Project Versions: 10,000 |
IOPS: Read: 15,000 / Write: 9,000 Black Duck Services: CPU: 10 core / Memory: 36 GB PostgreSQL: CPU: 2 core / Memory: 8 GB Total: CPU: 12 core / Memory: 44 GB |
120sph | Scans/Hour: 120 SPH % Increase: 0% APIs/Hour: 3,000 Project Versions: 13,000 |
IOPS: Read: 15,000 / Write: 15,000 Black Duck Services: CPU: 11 core / Memory: 56 GB PostgreSQL: CPU: 4 core / Memory: 16 GB Total: CPU: 15 core / Memory: 72 GB |
250sph | Scans/Hour: 300 SPH % Increase: 20% APIs/Hour: 7,500 Project Versions: 15,000 |
IOPS: Read: 15,000 / Write: 15,000 Black Duck Services: CPU: 16 core / Memory: 85 GB PostgreSQL: CPU: 6 core / Memory: 24 GB Total: CPU: 22 core / Memory: 109 GB |
500sph | Scans/Hour: 650 SPH % Increase: 30% APIs/Hour: 18,000 Project Versions: 18,000 |
IOPS: Read: 25,000 / Write: 25,000 Black Duck Services: CPU: 23 core / Memory: 133 GB PostgreSQL: CPU: 16 core / Memory: 64 GB Total: CPU: 39 core / Memory: 197 GB |
1000sph | Scans/Hour: 1400 SPH % Increase: 40% APIs/Hour: 26,000 Project Versions: 25,000 |
IOPS: Read: 25,000 / Write: 25,000 Black Duck Services: CPU: 44 core / Memory: 367 GB PostgreSQL: CPU: 22 core / Memory: 88 GB Total: CPU: 66 core / Memory: 455 GB |
1500sph | Scans/Hour: 1600 SPH % Increase: 6% APIs/Hour: 41,000 Project Versions: 28,000 |
IOPS: Read: 25,000 / Write: 25,000 Black Duck Services: CPU: 53 core / Memory: 464 GB PostgreSQL: CPU: 26 core / Memory: 104 GB Total: CPU: 79 core / Memory: 568 GB |
2000sph | Scans/Hour: 2300 SPH % Increase: 15% APIs/Hour: 50,000 Project Versions: 35,000 |
IOPS: Read: 30,000 / Write: 30,000 Black Duck Services: CPU: 64 core / Memory: 565 GB PostgreSQL: CPU: 32 core / Memory: 128 GB Total: CPU: 96 core / Memory: 693 GB |
Name | Details | |
---|---|---|
10sph | Scans/Hour: 50 PostgreSQL CPU/Memory: 2 core / Memory: 8 GB
|
maintenance_work_mem (MB):
512
|
120sph | Scans/Hour: 120 PostgreSQL CPU/Memory: CPU: 4 core / Memory: 16 GB
|
maintenance_work_mem (MB):
512
|
250sph | Scans/Hour: 300 PostgreSQL CPU/Memory: CPU: 6 core / Memory: 24 GB
|
maintenance_work_mem (MB):
1024
|
500sph | Scans/Hour: 650 PostgreSQL CPU/Memory: CPU: 16 core / Memory: 64 GB
|
maintenance_work_mem (MB):
1024
|
1000sph | Scans/Hour: 1400 PostgreSQL CPU/Memory: CPU: 22 core / Memory: 88 GB
|
maintenance_work_mem (MB):
2048
|
1500sph | Scans/Hour: 1600 PostgreSQL CPU/Memory: 26 core / Memory: 104 GB
|
maintenance_work_mem (MB):
4096
|
2000sph | Scans/Hour: 2300 PostgreSQL CPU/Memory: 32 core / Memory: 128 GB
|
maintenance_work_mem (MB):
4096
|
Updated policy evaluation of Archived project version phase
The following changes have been made to the Archived project version phase:
- The policy expression for project version phase no longer allows 'Archived' as a value.
- Existing policy rules that contain project version phase and 'Archived' value will be automatically disabled.
- New policy rules and expression changes will no longer be evaluated on project versions in 'Archived' phase.
Updated PostgreSQL settings
Starting with Black Duck 2023.10.0, PostgreSQL settings will be automatically set in deployments using the PostgreSQL container. Customers using external PostgreSQL will still need to apply the settings manually.
Updated Black Duck Hosted Detect version
Black Duck 2023.10.0 now offers support for Black Duck Detect 9 on the Black Duck Detect page and support for Detect 7.x has ended. After upgrading to Black Duck 2023.10.0, customers currently using Detect 7.x will see a warning indicator stating that Detect 7.x has reached end of support and that upgrading is recommended. Please note, you will not be able to revert to Detect 7.x after changing this configuration.
Updated Artifactory and SCM integrations requirements
In order to use the Artifactory and SCM integrations in your environment, you must
have these features enabled on your registration key. Once enabled, you must add the
following in your values.yaml
file:
enableIntegration: true
Updated SCA as a Service deployment files
The deployment files used for SCA as a Service have been updated as follows:
-
Updated RabbitMQ image from 1.2.14 to 1.2.29
-
Added new environment variables in order to configure the ports to communicate correctly:
BLACKDUCK_RABBIT_LISTENERS_PORT: "5672"
BLACKDUCK_RABBIT_MANAGEMENT_PORT: "15672"
Updated Show Unmatched Components functionality
The BLACKDUCK_HUB_SHOW_UNMATCHED
property used to determine whether
or not "Unmatched Components" counts will be shown in project version components
view is now enabled by default.
Please note this change was made in Black Duck 2023.7.0 and was inadvertently left out of that version's release notes.
Updated audit trails for SBOM fields
The Activity tab for a project will now report the addition or modification to the following SBOM fields:
-
Package Supplier Name
-
Package Supplier Email
-
Package Supplier Type
Updated reporting database tables
The following tables have been updated:
A
created_at
column has been added to thecomponent_policies
table. This column contains a list of times when policy violations were created.-
A
purl
column has been added to thecomponent
table. The column contains the package URL for the component.
Updated reporting database
The details stored as channel_release_external_namespace
obtained
via API is now available via the component table of the reporting database as well.
It states the general namespace for the origin (maven, debian, ubuntu, etc).
Updated login page and frame
The login page and frame surrounding Black Duck has been updated.
Updated container scanning feature name
Black Duck Container Scanning - Limited Customer Availability has been renamed to Black Duck Secure Container (BDSC). Black Duck Secure Container scanning provides capabilities to identify components within container images, their layers and base images.
The Product Registration page has been updated accordingly.
Increased default storage service size on Kubernetes
Black Duck 2023.10.0 increases the container size and java heap size from 1GB storage / 512MB memory to 2GB storage / 1GB memory.
Container versions
-
blackducksoftware/blackduck-postgres:14-1.16
-
blackducksoftware/blackduck-postgres-upgrader:14-1.1
-
blackducksoftware/blackduck-postgres-waiter:1.0.10
-
blackducksoftware/blackduck-cfssl:1.0.23
-
blackducksoftware/blackduck-nginx:2.0.60
-
blackducksoftware/blackduck-logstash:1.0.34
-
blackducksoftware/blackduck-upload-cache:1.0.48
-
blackducksoftware/bdba-worker:2023.9.4
-
blackducksoftware/rabbitmq:1.2.32
-
blackducksoftware/blackduck-webui:2023.10.0
-
blackducksoftware/blackduck-authentication:2023.10.0
-
blackducksoftware/blackduck-bomengine:2023.10.0
- blackducksoftware/blackduck-documentation:2023.10.0
- blackducksoftware/blackduck-integration:2023.10.0
- blackducksoftware/blackduck-jobrunner:2023.10.0
- blackducksoftware/blackduck-matchengine:2023.10.0
- blackducksoftware/blackduck-redis:2023.10.0
- blackducksoftware/blackduck-registration:2023.10.0
- blackducksoftware/blackduck-scan:2023.10.0
- blackducksoftware/blackduck-storage:2023.10.0
-
blackducksoftware/blackduck-webapp:2023.10.0