the network and the cluster network are optional in the ceph config and with 'pveceph init', so only check if we have an ip address from those networks if it is actually configured
otherwise, the createosd call dies with an 'ip' error message even if it would work Signed-off-by: Dominik Csapak <d.csa...@proxmox.com> --- PVE/API2/Ceph/OSD.pm | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/PVE/API2/Ceph/OSD.pm b/PVE/API2/Ceph/OSD.pm index e1b0d807..a514c502 100644 --- a/PVE/API2/Ceph/OSD.pm +++ b/PVE/API2/Ceph/OSD.pm @@ -284,13 +284,15 @@ __PACKAGE__->register_method ({ my $osd_network = $ceph_conf->{global}->{cluster_network}; $osd_network //= $ceph_conf->{global}->{public_network}; # fallback - my $cluster_net_ips = PVE::Network::get_local_ip_from_cidr($osd_network); - if (scalar(@$cluster_net_ips) < 1) { - my $osd_net_obj = PVE::Network::IP_from_cidr($osd_network); - my $osd_base_cidr = $osd_net_obj->{ip} . "/" . $osd_net_obj->{prefixlen}; - - die "No address from ceph cluster network (${osd_base_cidr}) found on node '$nodename'. ". - "Check your network config.\n"; + if ($osd_network) { # check only if something is configured + my $cluster_net_ips = PVE::Network::get_local_ip_from_cidr($osd_network); + if (scalar(@$cluster_net_ips) < 1) { + my $osd_net_obj = PVE::Network::IP_from_cidr($osd_network); + my $osd_base_cidr = $osd_net_obj->{ip} . "/" . $osd_net_obj->{prefixlen}; + + die "No address from ceph cluster network (${osd_base_cidr}) found on node '$nodename'. ". + "Check your network config.\n"; + } } # FIXME: rename params on next API compatibillity change (7.0) -- 2.20.1 _______________________________________________ pve-devel mailing list pve-devel@pve.proxmox.com https://pve.proxmox.com/cgi-bin/mailman/listinfo/pve-devel