blob: 080fcba9b91c3d246cc3b340c77e6ff17c7c5d8d [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.hadoop.ozone.container.upgrade;
import org.apache.hadoop.hdds.upgrade.HDDSUpgradeAction;
import org.apache.hadoop.ozone.container.common.statemachine.DatanodeConfiguration;
import org.apache.hadoop.ozone.container.common.statemachine.DatanodeStateMachine;
import org.apache.hadoop.ozone.container.common.utils.HddsVolumeUtil;
import org.apache.hadoop.ozone.container.common.volume.HddsVolume;
import org.apache.hadoop.ozone.container.common.volume.MutableVolumeSet;
import org.apache.hadoop.ozone.container.common.volume.StorageVolume;
import org.apache.hadoop.ozone.upgrade.UpgradeActionHdds;
import org.apache.ratis.util.Preconditions;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import static org.apache.hadoop.hdds.upgrade.HDDSLayoutFeature.DATANODE_SCHEMA_V3;
import static org.apache.hadoop.ozone.upgrade.LayoutFeature.UpgradeActionType.ON_FINALIZE;
import static org.apache.hadoop.ozone.upgrade.UpgradeActionHdds.Component.DATANODE;
/**
* Upgrade Action for DataNode for SCHEMA V3.
*/
@UpgradeActionHdds(feature = DATANODE_SCHEMA_V3, component = DATANODE,
type = ON_FINALIZE)
public class DatanodeSchemaV3FinalizeAction
implements HDDSUpgradeAction<DatanodeStateMachine> {
public static final Logger LOG =
LoggerFactory.getLogger(DatanodeSchemaV3FinalizeAction.class);
@Override
public void execute(DatanodeStateMachine dsm) throws Exception {
LOG.info("Upgrading Datanode volume layout for Schema V3 support.");
// Load RocksDB for each HddsVolume, build the relationship between
// HddsVolume and DbVolume if DbVolume is configured.
MutableVolumeSet dataVolumeSet = dsm.getContainer().getVolumeSet();
MutableVolumeSet dbVolumeSet = dsm.getContainer().getDbVolumeSet();
Preconditions.assertNotNull(dataVolumeSet,
"Data Volume should not be null");
dataVolumeSet.writeLock();
try {
for (StorageVolume hddsVolume : dataVolumeSet.getVolumesList()) {
HddsVolume dataVolume = (HddsVolume) hddsVolume;
if (dataVolume.getDbParentDir() != null) {
// The RocksDB for this hddsVolume is already created(newly added
// volume case).
continue;
}
dataVolume.createDbStore(dbVolumeSet);
}
} finally {
dataVolumeSet.writeUnlock();
}
DatanodeConfiguration dcf =
dsm.getConf().getObject(DatanodeConfiguration.class);
if (!dcf.getContainerSchemaV3Enabled()) {
LOG.info("Schema V3 is disabled. Won't load RocksDB in upgrade.");
return;
}
HddsVolumeUtil.loadAllHddsVolumeDbStore(
dataVolumeSet, dbVolumeSet, false, LOG);
}
}