[ 
https://issues.apache.org/jira/browse/HDFS-17463?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17837681#comment-17837681
 ] 

ASF GitHub Bot commented on HDFS-17463:
---------------------------------------

XbaoWu commented on code in PR #6736:
URL: https://github.com/apache/hadoop/pull/6736#discussion_r1567203473


##########
hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/namenode/FSImageFormatPBINode.java:
##########
@@ -628,25 +638,59 @@ private void loadRootINode(INodeSection.INode p) {
   public final static class Saver {
     private long numImageErrors;
 
-    private static long buildPermissionStatus(INodeAttributes n) {
-      return n.getPermissionLong();
+    private static long buildPermissionStatus(INodeAttributes n,
+        boolean enableSaveSplitIdStringTable) {
+      if(enableSaveSplitIdStringTable){
+        return n.getPermissionLong();
+      } else {
+        StringTable serialStringTable = 
SerialNumberManager.getSerialStringTable();
+        Map<String, Integer> stringMap = StreamSupport
+            .stream(serialStringTable.spliterator(), false)
+            .collect(Collectors.toMap(Map.Entry::getValue, Map.Entry::getKey));
+
+        long permission = n.getPermissionLong();
+        permission = USER.BITS.combine(stringMap.get(n.getUserName()), 
permission);
+        permission = GROUP.BITS.combine(stringMap.get(n.getGroupName()), 
permission);
+        return permission;
+      }
     }
 
-    private static AclFeatureProto.Builder buildAclEntries(AclFeature f) {
+    private static AclFeatureProto.Builder buildAclEntries(AclFeature f,
+        boolean enableSaveSplitIdStringTable) {
       AclFeatureProto.Builder b = AclFeatureProto.newBuilder();
+      Map<String, Integer> stringMap = null;
+      if(!enableSaveSplitIdStringTable){
+        StringTable serialStringTable = 
SerialNumberManager.getSerialStringTable();
+        stringMap = StreamSupport.stream(serialStringTable.spliterator(), 
false)
+                .collect(Collectors.toMap(Map.Entry::getValue, 
Map.Entry::getKey));
+      }
+
       for (int pos = 0, e; pos < f.getEntriesSize(); pos++) {
         e = f.getEntryAt(pos);
+        if(!enableSaveSplitIdStringTable){
+          e = (int) 
NAME.BITS.combine(stringMap.get(AclEntryStatusFormat.getName(e)), e);
+        }
         b.addEntries(e);
       }
       return b;
     }
 
-    private static XAttrFeatureProto.Builder buildXAttrs(XAttrFeature f) {
+    private static XAttrFeatureProto.Builder buildXAttrs(XAttrFeature f, 
boolean enableSaveSplitIdStringTable) {
       XAttrFeatureProto.Builder b = XAttrFeatureProto.newBuilder();
+      Map<String, Integer> stringMap = null;
+      if(!enableSaveSplitIdStringTable){
+        StringTable serialStringTable = 
SerialNumberManager.getSerialStringTable();

Review Comment:
   Yes, when enableSaveSplitIdStringTable is false, getSerialStringTable is 
called ; conversely, getStringTable is called. The mapping relations stored in 
these two StringTable are different.





> Support the switch StringTable Split ID feature
> -----------------------------------------------
>
>                 Key: HDFS-17463
>                 URL: https://issues.apache.org/jira/browse/HDFS-17463
>             Project: Hadoop HDFS
>          Issue Type: Improvement
>          Components: namenode
>    Affects Versions: 3.2.0, 3.3.5, 3.3.3, 3.3.4
>            Reporter: wangzhihui
>            Priority: Major
>              Labels: pull-request-available
>         Attachments: Image_struct.png, error.png
>
>
> desc:
>  * 
> Hadoop 3.2 introduced optimization features for HDFS StringTable 
> (b60ca37914b22550e3630fa02742d40697decb3), It resulted in lower versions of 
> Hadoop upgraded to 3.2 and later versions not supporting downgrade 
> operations. 
> !error.png!
>  * This issue has also been discussed in HDFS-14831, and it is recommended to 
> revert the feature, but it cannot fundamentally solve the problem。
>  * 
> Therefore, we have added an optimization to support downgrading
>  
> Solution:
>  * First, we will add the "dfs. image. save. splitId. stringTable" conf 
> switch "StringTable optimization feature" is enabled
>  * When the conf value is false, an Image file compatible with lower versions 
> of HDFS is generated to support downgrading.
>  * 
> The difference in HDFS Image file format between Hadoop 3.1.1 and Hadoop 3.2 
> is shown in the following figure.
>  * With the sub-sections feature introduced in HDFS-14617, Protobuf can 
> support compatible reading.
>  * 
> The data structure causing incompatible differences is mainly StringTable.
> !Image_struct.png|width=396,height=163!
>  * In "dfs.image.save.splitId.stringTable = false " the Id generation order 
> of StringTable starts from 0 to Integer.Max. When true, the Id value range 
> follows the latest rules.
>  



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

---------------------------------------------------------------------
To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org
For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org

Reply via email to